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SYSTEM TO ESTABLISH A CUSTOMER-SPECIFIED PRICE OF A PRODUCT AND 
TO MANAGE REDEMPTION OF THE PRODUCT AT THE ESTABLISHED PRICE 

CROSS-REFERENCE TO RELATED APPLICATIONS 

This application hereby claims priority from U.S. Provisional Application Serial No. 
60/173,458 filed December 29, 1999, titled "Name Your Own Price for Gas," the contents of 
which are incorporated by reference herein for all purposes. 

This application is a continuation-in-part of co-pending U.S. Patent Application Serial 
No. 09/337,906, filed June 22, 1999, for "Purchasing Systems and Methods Wherein a Buyer 
Takes Possession at a Retailer of a Product Purchased Using a Communication Network", 
and of co-pending U.S. Patent Application Serial No. 08/889,589, filed July 8, 1997, for 
"System and Method for EstabUshing and Managing Subscription Purchase Agreements 
Including Commitments to Purchase Good Over Time at Agreed Upon Prices", the contents 
of which are incorporated by reference herein for all purposes. 

This application is related to co-pending U.S. Patent Application Serial No. 
09/338,723, filed September 2, 1999, for "Purchasing Systems and Methods Wherein a Buyer 
Takes Possession at a Retailer of a Product Purchased Using a Communication Network", the 
contents of which are incorporated by reference herein for all purposes. 

FIELD OF THE INVENTION 

The present invention relates to the sale and redemption of products. More 
specifically, the present invention relates to a system enabUng a customer to establish a 
customer-specified price per unit of a product, and to redeem the product from a retailer. 

BACKGROUND OF THE INVENTION 

Conventional product retailers employ many methods designed to encourage 
customers to visit their retail stores. According to one method, a retailer advertises a sale 
price of a product which is less than the retailer's cost for the product. The product is 
referred to as a "loss leader", because a sale at the sale price results in a loss for the retailer. 
Accordingly, the advertised sale price is not intended to generate profits, rather, the sale price 
is simply intended to draw a customer into the retailer's store. Of course, the retailer hopes 
that the customer purchases other products once drawn into the store, and that profits from 
the sale of these other products offset any losses incurred due to the sale of the loss leader. 
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The retailer also hopes that the customer's visit will help to establish a behavior pattern by 
which the customer will tend to re-visit the store. 

Several problems exist with the above-described method. First, many manufacturers 
of desirable name-brand products prohibit retailers from selling the name-brand products at a 
5 deep discount for fear of dilution of their brands' market status. Therefore, most products 
offered as loss leaders are not popular and are Hmited in their ability to draw customers to a 
store. Second, the method does not prevent a customer from purchasing only the loss leader 
and no other products from the retailer, in which case the retailer simply incurs a loss. In 
addition, and despite the retailer's hopes, the customer may never again visit the store after 
1 0 purchasing the loss leader. 

One system has been developed to address the foregoing deficiencies. The system, 
described in detail in commonly-assigned co-pending Application Serial No. 08/889,589, 
cl entitled "System and Method for Establishing and Managing Subscription Purchase 

{f. Agreements Including Commitments to Purchase Good Over Time at Agreed Upon Prices", 

; j: 1 5 generally allows a customer to establish an agreement with a retailer to redeem a specified 
number of units of a product at a fixed price over a specified period of time or a specified 
Tfi number of visits. Customers are encouraged to use the system because the fixed price 

enables the customers to guard against price increases and, in some embodiments, the fixed 
y price is less than the retail price for the product. Retailers are advantaged because customers 

:J 20 must periodically re- visit their stores according to the agreements, which may influence the 
O customers to visit the stores even after the agreements are completed, and because the 

agreements provide locked-in prices, reliable indications of fiiture demand, and a competitive 
advantage over retailers who do not honor such agreements. 

Another system is needed for establishing and managing agreements for the purchase 
25 of products which may be priced per unit and redeemed in fractional units. Gasoline is one 
such fractionally-redeemable product, hi addition, because of shortcomings in conventional 
systems, purchases at gasoline stations are promoted using conventional techniques such as 
frequent buyer programs, prepaid debit cards, and the like. These techniques do not provide 
retailers with any agreement resulting in locked-in prices, reliable indications of future 
30 demand, or strong influences over customer behavior. In addition, these techniques do not 
allow customers to guard against price increases or to pay less than a retail price for a 
product. Accordingly, these systems are not particularly attractive to retailers or customers. 
As a result, what is needed is an improved system for selling products priced per unit and 
redeemable in fractional units. 

2 
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SUMMARY OF THE INVENTION 

In order to address the foregoing, the present invention provides, in one aspect, a 
system to establish an agreement with a customer to provide a number of units of a product 
for an agreement price, to arrange with a retailer to have the product redeemed at the retailer, 
and to receive data indicating a redemption of a fractional number of units of the product. 

In another aspect, the present invention provides a system to receive a redemption 
identifier from a customer, to retrieve data indicating an agreement to provide a number of 
units of a product for a customer-specified agreement price based on the redemption 
identifier, and to provide a second number of units of the product to the customer, wherein 
the second number is a non-integer. 

In an additional aspect, the present invention concerns means for creating an 
agreement with a customer to provide a number of units of a product for an agreement price, 
means for planning with a retailer to have the product redeemed at the retailer, and means for 
obtaining data indicating a redemption of a fractional number of imits of the product. 

As a result of each of the foregoing aspects, a retailer is provided with indications of 
fiiture demand and a system to establish customer loyalty. Moreover, a customer is provided 
with convenience, protection against price increases, and an ability, in some embodiments, to 
pay less than a retail price for a product. 

With these and other advantages and features of the invention that will become 
hereinafter apparent, the nature of the invention may be more clearly understood by reference 
to the following detailed description of the invention, the appended claims and to the several 
drawings attached hereto. 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. lA is a block diagram of an overall architecture of a system according to one 
embodiment of the present invention; 

FIG. IB is a block diagram of an overall architecture of a system according to one 
embodiment of the present invention; 

FIG. 2A is a block diagram of a controller according to one embodiment of the 
present invention; 

FIG. 2B is a block diagram of a controller according to one embodiment of the 
present invention; 

3 
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FIG. 3 is a block diagram of a customer device according to one embodiment of the 
present invention; 

FIG. 4A is a block diagram of a retailer device according to one embodiment of the 
present invention; 

5 FIG. 4B is a block diagram of a retailer device according to one embodiment of the 

present invention; 

FIG. 5 is a block diagram of a customer terminal according to one embodiment of the 
present invention; 

FIG. 6 illustrates a tabular representation of a portion of a retailer database according 
10 to one embodiment of the present invention; 

FIG. 7 illustrates a tabular representation of a portion of a retailer restriction database 
according to one embodiment of the present invention; 
r3 FIG. 8 illustrates a tabular representation of a portion of a retailer settlement database 

I fi according to one embodiment of the present invention; 

'j! 15 FIG. 9 illustrates a tabular representation of a portion of a subsidy database according 

y to one embodiment of the present invention; 

'5 FIG. 1 0 illustrates a tabular representation of a portion of a redemption condition 

JL, database according to one embodiment of the present invention; 

I d FIG- 1 1 illustrates a tabular representation of a portion of a customer database 

^2 20 according to one embodiment of the present invention; 

Q FIG. 12 illustrates a tabular representation of a portion of an agreement datable 

according to one embodiment of the present invention; 

FIG. 13 illustrates a tabular representation of a portion of a retailer redemption 
database according to one embodiment of the present invention; 
25 FIG. 14 is a flow chart of process steps of a transaction according to one embodiment 

of the present invention; 

FIG. 15 is a flow chart of process steps to establish an agreement according to one 
embodiment of the present invention; 

FIG. 16 is a flow chart of process steps to receive an offer according to one 
30 embodiment of the present invention. 

FIG. 17 illustrates tables associating discount amounts and acceptance probabilities 
according to one embodiment of the present invention. 

FIG. 18 is a flow chart of process steps to determine acceptability of an offer 
according to one embodiment of the present invention. 

4 
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FIG. 19, comprising FIG. 19A and FIG. 19B, illustrates tables used to determine a 
retailer to bind to an agreement according to one embodiment of the present invention. 

FIG. 20 is a general flow chart of process steps of a product redemption according to 
one embodiment of the present invention; 
5 FIG. 2 1 is a flow chart of process steps to authorize a product redemption according 

to one embodiment of the present invention; 

FIG. 22 is a flow chart of process steps to manage a product redemption according to 
one embodiment of the present invention; 

FIGS. 23A and 23B illustrate a detailed flow chart of process steps to manage a 
10 product redemption according to one embodiment of the present invention; 

FIGS. 24A and 24B illustrate a detailed flow chart of process steps to manage a 
product redemption according to one embodiment of the present invention; 

FIGS. 25A and 25B illustrate a detailed flow chart of a product redemption according 
to one embodiment of the present invention; 
15 FIG. 26 is a general flow chart of process steps of a settlement process according to 

one embodiment of the present invention; and 

FIGS. 27A and 27B illustrate a detailed flow chart of process steps of a settlement 
process according to one embodiment of the present invention. 



20 DETAILED DESCRIPTION OF THE INVENTION 

To insure clarity of the following description, set forth below are definitions of terms 
used herein. The scope of the present invention is not to be deemed limited by the 
definitions. 

Agreement Product: A product of which a customer agrees to purchase a number of 
25 units. An agreement product may be specified in general terms. For example, a customer 
may specify as an agreement product any gasoline having an octane rating between 85 and 
90. 

Agreement Price: A price for which a customer agrees to purchase a number of units 
of an agreement product. Examples include a total purchase price for the number of units, a 
30 price per unit, a percentage off a retail price, and a dollar amount less than a retail price. In a 
case that a product is full service gasoline, the agreement price may be a retail price of self- 
service gasoline. 

Offer Product: A product of which a customer offers to purchase a number of units. 
After the offer is accepted, the offer product becomes an agreement product. 
5 
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Offer Price: A price for which a customer offers to purchase a number of imits of an 
offer product. The offer price becomes an agreement price once the offer is accepted. 

Retailer: Any person, group of persons or entity such as a manufacturer, department 
store, grocery store, or gasoline station from which a customer can redeem an agreement 
5 product. 

Settlement Price: A price for which a retailer agrees to provide a product to a 
customer. The settlement price may be established by an agreement between the retailer and 
a third party providing a system according to the invention. The settlement price may be paid 
to a party other than the retailer. 
10 Settlement Schedule: A schedule by which a settlement price is paid to a retailer, 

either by a customer, a third party, or both. A settlement schedule may be time-based 
(monthly), event-based (after each redemption), or otherwise defined. 

r As an introduction to the following detailed description, a particular embodiment of 

r 15 the present invention will now be presented. According to this embodiment, a customer 
- establishes an agreement to purchase a number of gallons of gasoline and redeems the 

2: gasoline from a gasoline retailer. Specifically, the customer uses a personal computer to 

:^ request a web page from a web site provided by a controller. The customer enters location 

information, such as a ZIP code, and information specifying an offer product, such as 89 
^ 20 octane, into the web page and fransmits the information to the confroller. In response, the 

controller identifies gasoline retailers that provide the offer product and are located within the 
ZIP code. The customer selects several of the identified retailers, and is presented with an 
average price per gallon offered by the selected retailers for the specified product. The 
customer then selects an offer price, which is a price per gallon that may be less than the 
25 average price, selects a desired number of gallons of the offer product, and fransmits the 
selections along with payment information such as a credit card account number to the 
controller. 

The confroller determines that the offer price is acceptable and transmits a web page 
notifying the customer that the offer has been accepted, thereby establishing an agreement to 
30 provide the desired number of gallons of the offer product, now the agreement product, for 
the offer price, now the agreement price. In addition, the confroller specifies at least one 
gasoline retailer at which the agreement product may be redeemed under the agreement. The 
customer's credit card account is then charged for the agreement. The credit card account is 
charged an amount equal to the agreement price multiplied by the number of desired gallons. 
6 
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In order to redeem the gasoline under the agreement, the customer presents a 
redemption identifier to one of the specified gasoline retailers. The redemption identifier 
may be information identifying the agreement encoded on a magnetic strip of an 
identification card. The card is swiped through a card reader provided by a gasoline pump, 
5 and the card reader extracts the information encoded thereon. The identifying information is 
then transmitted to the controller, which uses the information to retrieve agreement 
information corresponding to the agreement previously established with the customer. The 
controller transmits the agreement information back to the gasoline pump, which is set to 
dispense up to the amount specified under the agreement. The customer redeems a desired 
10 number of gallons and the redeemed number of gallons is transmitted to the controller. The 
controller updates the agreement information to reflect the redemption and pays the gasoline 
retailer an agreed upon settlement price per gallon multiplied by the redeemed number of 
gallons. 

It should be noted that the amount received by the controller from the customer may 
_ 1 5 be less than a payment made by the controller to the retailer. The present invention allows 
the controller to make up for this shortfall in several ways. For example, prior to accepting 
~ an offer, the controller may calculate that the offer, if accepted, will result in a $10.00 

^ shortfall. Accordingly, the controller checks a database of subsidy offers and finds that a 

long distance provider will provide a $20.00 subsidy for each customer who agrees to switch 
^ 20 to the long distance service provider. Therefore, prior to accepting the offer, the controller 
f determines if the customer is willing to switch to the long distance provider. If so, the 

controller accepts the offer, receives the $20.00 subsidy fi-om the long distance provider, uses 
$10.00 of the $20.00 to make up for the shortfall, and keeps $10.00 as profit. 

It should be noted that the foregoing example is intended as an introduction to the 
25 detailed description, and the present invention is not limited to the particular steps described 
above. 

SYSTEM 

Turning to the drawings, FIG. lA shows a block diagram of a system 10 according to 
30 embodiments of the present invention. As shown, the system 10 includes a controller 200 in 
communication with customer devices 100, 101 and 102 as well as retailer devices 300, 301 
and 302. Although the communication media between the customer devices 100, 101 and 
102, the retailer devices 300, 301 and 302 and the controller 200 are represented by dedicated 
connections, it should be understood that one or more of the customer devices 100, 101 and 
7 
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102 and the retailer devices 300, 301 and 302 may be connected to a network, such as a Local 
Area Network (LAN) or a Wide Area Network (LAN), to which is also connected the 
controller 200. The network may also be an Internet Protocol (IP)-based network, such as the 
World Wide Web; or one of a satellite-based network; a cellular network; a radio frequency 
5 (RF) network; a telephone network; a cable television network; a bulletin board system; or 
any other communication media for transferring data between locations. 

The controller 200 may be a computer server, such as a Sun® Solaris® server 
providing a database server and a web server. The controller 200 may be operated by a 
product manufacturer, such as a gasoline refiner; by an entity providing customer acquisition 
10 services to manufacturers; by an entity providing shopping and retail services to customers; 
or by any other entity to which the present invention may provide benefits. In the following 
description, actions of an entity operating the controller 200 will be imputed to the controller 
•i 200, such as payment of an amount, reception of payment, etc. Multiple physical devices 

may be used to perform the functions of controller 200 according to the present invention, 
5 15 and some or all of these functions may also be performed manually. 
J One or more of the customer devices 100, 101 and 102 may comprise a personal 

computer, such as those based on the Intel® Pentium® processor; a dedicated terminal; an 
> Internet kiosk; a personal digital assistant; a pager; a cellular phone; a pay phone; a video 

game; an automated teller machine; a slot machine; a watch; a vending machine; an in-car 
== 20 communications system, such as the NAVSTAR system, for providing data such as global 
% positioning system information, traffic information or the like; or any other device adapted to 
communicate with the controller 200 over whatever communication media happen to exist 
between the particular device and the controller 200. For example, in a case that the 
customer device 100 communicates with the controller 200 over the World Wide Web, the 
25 customer device 100 may execute a web browser application for passing data to the controller 
200 and/or requesting data from the controller 200. Although three customer devices and 
three retailer devices are shown in FIG. 1 A, any number of customer devices and retailer 
devices may be in communication with the controller 200 according to the invention. 
One or more of the retailer devices 300, 301 and 302 may comprise a personal 
30 computer or a network server such as an IBM AS/400 server. In one embodiment, each of 
the retailer devices 300, 301 and 302 is located at a respective retailer and includes data for 
its respective retailer. Such data may include inventory data, payroll data, sales data, and any 
other data used during the operation of a retail establishment. The retailer devices 300, 301 

8 
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and 302 may also comprise dedicated terminals used primarily to operate in conjunction with 
a system according to the present invention, or credit/debit card authorization terminals 
provided with software enabling operation in accordance with the present invention. 

In communication with respective ones of the retailer devices 300, 301 and 302 are 
5 redemption devices 410, 4 11 and 421. The redemption devices 401, 41 1 and 421 may 

communicate with the retail devices using known media for transporting electrical signals or 
other communications, and are used to dispense a product to a customer according to the 
present invention. As described below, each redemption device 401, 41 1 and 412 may be 
controlled by a respective retailer device 300, 301 or 302, or by the controller 200. 

10 FIG. IB is a block diagram of a retail system 20 according to other embodiments of 

the present invention. Shown in FIG. IB are the controller 200 and the retailer devices 300, 
301 and 302, as described with respect to FIG. 1 A. Also shown are customer terminals 400, 
410 and 420 in cormnimication with the controller 200. Each of the customer terminals 400, 
410 and 420 comprises a redemption device and an offer submission device which, as 

1 5 illustrated by a broken line, may be located in one physical unit or in separate units. The 
redemption devices 401, 41 1 and 421 are used to dispense a product to a customer and the 
offer submission devices 402, 412 and 422 are used by a customer to submit an offer to the 
controller 200. In one embodiment, the customer terminal 400 is a gasoline pump, the 
redemption device 401 comprises a pumping mechanism, a hose and nozzle using which 

20 gasoline is dispensed, and the offer submission device 402 comprises an input device such as 
a keypad and a display, such as an LCD, LED, or a flat panel display, using which a customer 
submits an offer as described below. The offer submission device 402 may also be used to 
display instructions or advertisements to a customer and to receive payment information, 
such as a credit card or debit card number, from the customer. 

25 A retailer device may communicate directly with a customer terminal as well as with 

the controller 200, as shown with respect to the retailer device 300 and the customer terminal 
400. As will be described in detail below, this communication enables the retailer device 300 
to control the redemption device 401 so as to dispense only as many units of a product as are 
remaining under an agreement, to receive redemption information directly from the 

30 redemption device 401, or for any other purpose. In the following description, transmission 
of data to a retailer and reception of data from a retailer may be performed using either of a 
retailer device or a customer terminal. 

In another embodiment, a customer communicates directly with a retailer device using 
a redemption tool, such as a personal digital assistant or a smartcard. In this regard, 
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communication is established between the redemption tool and the retailer device through an 
appropriate interface and redemption information is transmitted to the retailer device from the 
redemption tool. Such an arrangement can be used, for example, in embodiments using a 
redemption identifier which encodes all the information needed for redemption. As a result, 
the retailer device and/or an associated customer terminal need not be in communication with 
the controller 200 before, during, or after redemption. 

It should be noted that, in some embodiments, a single unit, such as a gasoline pump, 
comprises a retailer device, a redemption device and an offer submission device, and that the 
single unit is in communication with the controller 200. Li other embodiments, a retailer 
device and a customer device as shown in FIG. 1 A are housed in a same unit. 

Those skilled in the art will understand that devices in communication with each other 
need not be continually transmitting to each other. On the contrary, such devices need only 
to transmit to each other as necessary, and may actually refrain from exchanging data most of 
the time. For example, a device in communication with another device over the World Wide 
Web may not transmit data to the other for weeks at a time. 

DEVICES 

Controller 

FIG. 2A illusfrates an embodiment of the controller 200. The controller 200 may be 
implemented using a network server, a dedicated hardware circuit, an appropriately- 
programmed general purpose computer, or any other equivalent electronic, mechanical or 
elecfro-mechanical device. 

The controller 200 of FIG. 2 A comprises a processor 210, such as one or more 
RISC® processors. The processor 210 is coupled to a communication port 220 through 
which the controller 200 communicates with other devices, such as the customer devices 100, 
101 and 102. As mentioned above, each of the customer devices 100, 101 and 102 may 
communicate with the controller 200 over different communication media. Accordingly, the 
communication port 220 is configured, in one embodiment, to communicate using hardware 
and software protocols of the different media. In addition, the controller 200 can 
commimicate with locally-attached devices through the communication port 220. 

Also connected to the processor 210 are an input device 230, a display 240 and a 
printer 250. The input device 230 may be any device for inputting data, such as a keyboard, a 
touch screen, a mouse, a voice input device, an infrared port, or the like. The input device 
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230 can be used by personnel to enter data used by the controller 200 in accordance with the 
present invention. Data may also be input to the controller 200 using a device connected, 
either directly or over a communication medium, to the communication port 220. 

The display 240 is used to output graphics and text and may be a CRT computer 
5 monitor, a flat panel display or another type of display device. Data can also be output by the 
printer 250 in hard copy format. In one embodiment, such data comprises redemption 
information, agreement information, and transaction histories. 

The processor 210 is also in communication with a data storage device 260. The data 
storage device 260 is generally a data memory and may include any appropriate combination 
10 of magnetic, optical and/or semiconductor memory. The data storage device 260 may also 
include, for example. Random Access Memory (RAM), Read Only Memory (ROM), a 
compact disc and/or a hard disk. Furthermore, the processor 210 and the storage device 260 
'-^ may each be, for example: (i) located entirely within a single computer or other computing 
=- device; or (ii) connected to each other by remote communication media such as a serial port 
= 15 cable, telephone line or radio frequency transceiver. In one embodiment, the controller 200 

comprises one or more computers that are connected to a remote server computer for 
5^ maintaining databases. 

The data storage device 260 stores a program 500 of processor-executable process 
steps. The processor 210 executes the process steps of the program 500 and thereby operates 
J 20 in accordance with the present invention, and particularly in accordance with the methods 
^ described herein with respect to the controller 200. The program 500 may be stored in a 

compressed, uncompiled and/or encrypted format. The process steps of the program 500 can 
be stored in the storage device 260 during manufacture of the storage device 260, can be 
downloaded from a compact disc or other computer-readable medium, or can be retrieved 
25 from a remote or local source through the communication port 220 in the form of a signal 

having the process steps encoded thereon. The data storage device 260 also stores processor- 
executable process steps for basic operation of the controller 200, such as process steps of an 
operating system, a database management system and "device drivers" for allowing the 
controller 200 to interface with computer peripheral devices. These latter process steps are 
30 known to those skilled in the art, and are therefore not described in detail herein. 

According to one embodiment of the present invention, the steps of the program 500 
are transferred from the data storage device 260 into a main memory, such as a RAM, and 
executed therefrom by the processor 210. In alternate embodiments, hard-wired circuitry 
may be used in place of, or in combination with, processor-executable software process steps 
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for implementation of the processes of the present invention. Thus, embodiments of the 
present invention are not limited to any specific combination of hardware or software. 

The storage device 260 also stores i) a retailer database 600, ii) a retailer restriction 
database 700, iii) a retailer settlement database 800, iv) a subsidy database 900, v) a 
5 redemption condition database 1000, vi) a customer database 11 00, vii) an agreement 

database 1200, and viii) a retailer redemption database 1300. The databases 600 to 1300 are 
described in detail below and portions thereof are depicted in tabular form with sample 
entries in the accompan3dng figures, hi this regard, and as will be imderstood by those skilled 
in the art, the schematic illustrations and accompanying descriptions of the databases 
10 presented herein are merely intended to demonstrate operable systems for associating and 
storing information. A number of other data structures may be employed besides those 
suggested by the tables shown. Similarly, the illustrated entries of the databases represent 
O sample information only; those skilled in the art will understand that the number and content 
Hji of the entries can be different from those illustrated. 

+ 1 5 FIG. 2B is a block diagram of the controller 200 according to an embodiment of the 

'^1 invention in which an offer is received from a customer by the controller 200 and is routed to 

7n participating retailers. The processor 210, the communication port 220, the input device 230, 

the display 240 and the printer 250 shown in FIG. 2B possess characteristics similar to those 
ijj described with respect to FIG. 2A. 

fl 20 The storage device 290 includes a program 501 of processor-executable process steps 

Q to route an offer to retailers, to establish an agreement with a customer, and to manage a 
redemption of a product. In this regard, the storage device 290 includes a retailer routing 
database 601 containing data which is used to identify retailers and to route offers to the 
retailers. Operation of the embodiment reflected in FIG. 2B will be described below. 

25 

Customer Device 

FIG. 3 illustrates certain elements of the customer device 100. The customer device 
1 00 is used to input data to and receive data from the controller 200, and to present data to a 
customer. As shown, the device 1 00 includes a processor 1 1 0 connected to a communication 
30 port 120. The communication port 120 is used to transmit data to the controller 200, either 
via a network or a dedicated connection, and also to receive data from the controller 200. 
Also connected to the processor 1 10 is an input device 130 for receiving data from a 
customer, a display 140 for displaying data to the customer, and a printer 150 for creating a 
hardcopy of data, such as a redemption voucher for redeeming a product per an agreement 
12 
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with the controller 200. The input device 130, the display 140 and the printer 150 may 
comprise any of the input devices, displays, or printers discussed above. 

A storage device 160 is also connected to the processor 110, and stores data and 
processor-executable process steps for the operation of the customer device 100. For 
example, the storage device 160 stores data and process steps of an operating system 161 
which controls basic operation of the customer device 100. Also stored in the storage device 
160 are processor-executable process steps of a web browser application 162 which can be 
executed by the processor 1 10 to provide communication between the customer device 100 
and the controller 200 through the World Wide Web. Of coixrse, depending on the 
communication media disposed between the customer device 100 and the controller 200, 
other known applications or hardware may be needed for the customer device 100 to 
communicate with the controller 200. 

Retailer Device 

FIG. 4A is a block diagram showing several components of the retailer device 300 
according to one embodiment of the invention. According to one version of this 
embodiment, the retailer device 300 receives a redemption identifier from a customer 
requesting a redemption, transmits the redemption identifier to the controller 200, and 
receives authorization from the controller to provide a number of units of a product to the 
customer. The retailer device 300 then provides, or controls another device such as the 
redemption device 401 to provide, the product to the customer. After the redemption, the 
retailer device 300 transmits redemption information to the controller 200. 

The retailer device 300 includes a processor 310 for executing processor-executable 
process steps, and a communication port 320 connected thereto for communicating with the 
controller 200 over a network or a dedicated connection. The retailer device 300 may 
communicate with other retailer devices, customer devices or customer terminals over the 
communication port 320. 

Also connected to the processor 310 are an input device 330, a display 340 and a 
printer 350. The input device 330 can be used by a retailer to input data and instructions into 
the retailer device 300, such as data for controlling a customer terminal 400 to dispense a 
certain number of units of a product or redemption information for transmitting to the 
controller 200. The input device 330 may comprise a keyboard, a voice recognition unit, a 
touch screen, or other input system. The display 340 displays data to the retailer. For 
example, the display 340 may display details of a customer agreement with the controller 
13 
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200, based on which the retailer controls a customer redemption of a product, and may 
comprise a CRT display, a flat panel display, an LCD display, an LED display or the like. 
The printer 350 is used to create hardcopies of data received and/or generated by the retailer 
device 300, and may comprise a laser printer, a thermal printer, an ink jet printer, or the like. 

A storage device 360 is connected to the processor 310, and stores processor- 
executable process steps of a program 361 which are executed by the processor 310 so as to 
allow the retailer device 300 to operate in accordance with the present invention. The process 
steps of the program 361 can be stored in the storage device 360 during manufacture of the 
storage device 360, can be downloaded from a compact disc or other computer-readable 
medium, or can be retrieved from a remote or local source through the communication port 
320 in the form of a signal having the process steps encoded thereon. In one embodiment, 
the processor-executable process steps of the program 361 are executed by the processor 310 
to receive redemption information from a customer, to transmit the redemption information to 
the controller 200, to receive authorization from the controller 200 to provide a number of 
units of a product to the customer, to control the redemption device 401 to provide the 
product to the customer, to receive redemption information from the redemption device 401, 
and to transmit the redemption information to the controller 200. 

FIG. 4B is a block diagram of the retailer device 300 according to another 
embodiment of the invention. The reader is referred to the description of FIG. 4A for 
descriptions of the elements of FIG. 4B that are numbered identically to elements of FIG. 4A. 

In contrast to the retailer device 300 of FIG. 4B, the data storage device 360 of FIG. 
4B contains processor-executable process steps of a program 362 executed by the processor 
310 to receive agreement information from the controller 200, to store the agreement 
information in an agreement database 363 similar to the agreement database 1200, to receive 
redemption information from a customer, to determine a number of imits of a product to 
provide to the customer based on data in the agreement database 363, to control the 
redemption device 401 to provide up to the determined nimiber of units of the product to the 
customer, to receive redemption information from the redemption device 401, to update the 
agreement database 363 in accordance what the received redemption information, and to 
transmit the redemption information to the controller 200. Operation of the retailer device 
300 according to FIG. 4A and FIG. 4B will be described in more detail below. 

Customer Terminal 
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FIG. 5 is a block diagram of several elements of the customer terminal 400 in 
accordance with one embodiment of the present invention. As shown in FIG. 5, the customer 
terminal 400 includes a processor 415 connected to a communication port 425, an input 
device 430, a display 440 and a printer 450. The commimication port 425 is adapted to allow 
5 communication between the customer terminal 400, the retailer device 300, and/or the 

customer device 1 00, directly or over a network. The input device 430 may consist of a card 
reader, a keypad, a keyboard, a voice recognition system, or the like, and is used by a 
customer to input a redemption identifier, establish an agreement with the controller 200, 
modify an existing agreement or terminate an agreement. The display 440 is used to display 
10 instructions and data to the customer, and may be a flat panel display, an LCD display, an 
LED display, or the like. The printer 450 may be used to provide the customer with a record 
of a redemption, or with a redemption identifier or voucher for use in subsequent 
D redemptions. 

Ill The redemption device 401 of the customer terminal 400 is controlled by the 

IE 1 5 processor 41 5 to dispense a product. In a case that the product is gasoUne, the redemption 
= device 401 includes a pump, hose, nozzle and related electrical, mechanical and hydraulic 
equipment needed to dispense gasoline to a customer. 

Also included in the customer terminal 400 and connected to the processor 41 5 is a 
IaI storage device 470 storing processor-executable process steps of a program 471 using which 

=T 20 the customer terminal 400 operates in conjunction with embodiments of the invention. The 
5 process steps of the program 471 can be stored in the storage device 470 during manufacture 

of the storage device 470, can be downloaded from a compact disc or other computer- 
readable mediiun, or can be retrieved from a remote or local source through the 
communication port 425 in the form of a signal having the process steps encoded thereon. 
25 Generally, and according to one embodiment, the processor 415 executes the processor- 
executable process steps of the program 471 to receive agreement information from the 
controller 200, to store the agreement information in the agreement database 472, to receive a 
redemption identifier from a customer, to locate an agreement corresponding to the received 
redemption identifier in the agreement database 472, to control the redemption device 401 to 
30 dispense a product according to the agreement, to receive redemption information from the 
redemption device 401, to update the agreement database 472 in accordance with the 
redemption information, and to transmit the redemption information to the controller 200 via 
the communication port 425. 

15 
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In other embodiments, the processor 415 executes processor-executable process steps 
of the program 471 to receive an offer from a customer to purchase a number of units of an 
offer product for an offer price and to transmit the offer to the controller 200. According to 
these embodiments, a customer both estabHshes an agreement and redeems a product under 
the agreement at the customer terminal 400. 

DATABASES 

Retailer Database 

FIG. 6 shows a tabular representation of a portion of the retailer database 600 
according to an embodiment of the present invention in which the agreement products are 
types of gasoline and the product retailers are gasoline retailers. As will be described in 
detail below, the information stored in the retailer database 600 includes retailer-specific data 
that can be used to determine a specific retailer to bind to an agreement or to determine a 
settlement price due to a retailer. The database 600 may include any niunber of records, and 
includes fields for each record therein. The fields of FIG. 6 specify: i) a retailer identifier 
610 used throughout the databases stored in the storage device 260 to identify a particular 
retailer; ii) a location 620 of the retailer, which may be a full postal address, a ZIP code, GPS 
coordinates, latitude and longitude, or the Uke; iii) a manufacturer 630 of a product provided 
by the retailer; iv) a retail price (87) 640 for which the retailer sells a gallon of 87 octane 
gasoline; v) a retail price (89) 650 for which the retailer sells a gallon of 89 octane gasoline; 
and vi) a retail price (92) 660 for which the retailer sells a gallon of 92 octane gasoline. 

The retail prices 640 to 660 shown in the tabular representation may be updated 
automatically at periodic intervals, automatically in real time by receiving retail price data 
from the retailers corresponding to the retailer identifiers 610, or manually using the input 
device 230. Of course, records corresponding to retailers in addition to those shown in FIG. 
6 may be included in the retailer database 600. 

Retailer Restriction Database 

FIG. 7 is a tabular representation of a portion of the retailer restriction database 700 
according to one embodiment of the invention. The tabular representation shown includes 
several records, each associated with several fields. The fields specify: i) a retailer identifier 
710 which identifies a same retailer as an identical retailer identifier 610 of the retailer 
database 600; ii) a product 720; iii) a minimum agreement price 730; and iv) a minimum 
agreement quantity 740. The product 720 identifies a particular product sold by the retailer, 
16 
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while the minimum agreement price 730 and the minimum agreement quantity 740 are, in 
one embodiment, restrictions set by the retailer which are used as guidehnes by the controller 
200 when determining whether to accept a customer offer and when determining a retailer to 
be bound to an agreement. Usage of the retailer restriction database 700 will be described in 
5 more detail below. 

Retailer Settlement Database 

FIG. 8 illustrates a tabular representation of a portion of the retailer settlement 
database 800. The tabular representation contains several records, each specifying: i) a 
1 0 retailer identified by a retailer identifier 8 1 0; ii) a settlement price 820; iii) a settlement 

schedule 830; and iv) a commission fee 840. hi one embodiment, the retailer identifier 810 
refers to a same retailer as an identical retailer identifier 610 or 710 of the databases 600 and 
?□ 700, and can thereby be used to retrieve data for a particular retailer from any of the 

ll databases 600, 700 and 800. The settlement price 820 corresponding to a particular record 

;t 1 5 specifies a price which the controller 200 pays to the retailer corresponding to the record for 
M redemption of a product from the retailer, and the settlement schedule 830 specifies a time at 

ifl which the corresponding settlement price 820 is paid to the retailer. For example, in one 

embodiment, a customer establishes an agreement with the controller 200 to purchase 50 
y gallons of 87 octane gasoline for $1 .00 per gallon and pays the cenfral confroller $50.00 

U. 20 under the agreement. After the customer has redeemed 10 gallons of 87 octane gasoline from 
O the retailer R-000 1 , the retailer R-OOOl notifies the controller 200 that 1 0 gallons of 87 octane 

gasoline have been redeemed by the customer. According to the retailer database 600, the 
retail price for 87 octane gasoline [retail price (87) 640] offered by the retailer R-000 1 is 
$1.50 per gallon. Accordingly, since the settlement price 820 corresponding to retailer 
25 identifier 810 R-000 1 is equal to the retail price, the controller 200 pays the retailer R-000 1 
$1 .50 per gallon (10 gallons) = $15.00 at midnight after the redemption, as required by the 
settlement schedule 830. 

The settlement price 820 may be based on the customer's agreement price, the retail 
price of the product, or the cost of the product to the retailer or the controller 200. The 
30 settlement price 820 may be the regular retail price of the product at the time that the 

agreement is established or at the time that the customer redeems the product, or it could be 
an average or projected retail price over the redemption time period. The settlement price 
820 may also be a percentage, greater than or less than 100%, of the agreement price or the 
retail price, or the average of the agreement price and the retail price, hi addition, the 
17 
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settlement price 820 may be the same for all customers, or it may be dynamic, changing 
along with certain customer-related conditions. For example, the controller 200 may pay a 
lower settlement price for customers who agree to purchase larger quantities of the product. 
The settlement price may also be based on external factors such as political events, crude oil 
5 prices, the stock market, etc. 

The commission fee 840 specifies an amount which the corresponding retailer agrees 
to pay the controller 200 for sales/customers generated by the invention. For example, the 
retailer may agree to pay the controller 200 a fixed amount for each agreement assigned to 
the retailer, a fixed amount for a particular number of gallons of a product redeemed by a 
1 0 customer according to an agreement, or any other type of commission. It should be noted 
that the retailer settlement database 800 may include records corresponding to retailers in 
addition to those shown in FIG. 8. 

Subsidy Database 

+: 15 FIG. 9 is a tabular representation of a portion of the subsidy database 900 according to 

H one embodiment of the invention. Each record in the tabular representation of FIG. 9 

includes fields specifying: i) a subsidy identifier 910; ii) a subsidy provider 920; iii) an 
obligation 930; and iv) a subsidy amount 940. Generally, the subsidy database is used to 
Ly store information relating to subsidies which are paid to the controller 200 in return for 

s'^: 20 customer acceptance of an obligation 930. As will be described below, such subsidies can be 
Q used by the controller 200 to make up a difference between payments received from a 

customer under an agreement and payments made to retailers under the agreement. 
Accordingly, the data in the subsidy database 900 is used in one embodiment to determine 
whether or not to accept a customer offer. 
25 For example, a customer may submit an offer to the controller 200 to purchase 50 

gallons of 89 octane gasoline for an agreement price of $1.50. In response, the controller 200 
calculates that the customer will pay the controller 200 $1.50 per gallon (50 gallons) = $75.00 
if the offer is accepted. The retailer settlement database 800 indicates that the retailer 
identified by the retailer identifier 800 R-OOOl is paid a settlement price equal to a retail 
30 price, which, according to the retailer database 600, is $1 .70 per gallon for 89 octane 

gasoline. Accordingly, the controller 200 would be required to pay the retailer identified by 
the retailer identifier 800 R-OOOl ($1.70)(50) = $85.00 if the customer redeems 50 gallons of 
89 octane gasoline firom the retailer identified by the retailer identifier 800 R-OOOl . In order 
to make up for the $85.00 - $75.00 = $10.00 shortfall, the controller 200 analyzes the subsidy 
18 
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database 900 to locate a subsidy having a corresponding subsidy amount 940 of more than 
$10.00. The controller 200 thereby locates the subsidy identifier 910 Sub 01 and, per the 
obligation 930 corresponding to the subsidy identifier 910 Sub 01, determines whether the 
customer will agree to apply for a gold card. If so, the controller 200 accepts the offer, 
5 because the terms would result in a profit of $30.00 - $10.00 = $20.00. Further details of this 
process and related processes are set forth below. 

Redemption Condition Database 

A portion of a tabular representation of the redemption condition database 1000 is 
10 shown in FIG. 10. Records and fields in addition to those shown may be included in the 

redemption condition database 1000. Each record in the redemption condition database 1000 
includes fields specifying a redemption code 1010 and a redemption condition 1020. The 
O redemption code 1010 is used in other databases stored in the storage device 260 to identify 
lS an associated redemption condition 1020. In this regard, the redemption condition 1020 
Lt 1 5 associated with each redemption code 1010 specifies a condition which must be satisfied in 

order for a customer to redeem a product under an agreement. Accordingly, in some 
■g embodiments, a redemption condition 1020 is first evaluated before a customer is authorized 

to redeem a product under an agreement with the controller 200. 
ill Many types of redemption conditions 1020 can be specified in the redemption 

U. 20 condition database 1000. For example, a redemption condition 1020 may specify a particular 
H retailer or retailers which must be visited to redeem an agreement product, or a manufacturer 
whose retailers must be visited to redeem the product. The redemption condition 1020 may 
be an expiration date after which the agreement will expire, a maximum or minimum quantity 
of the agreement product that can be redeemed at one time under the agreement, or a certain 
25 time of day/week/month/year during which the product must be redeemed, such as an off- 
peak time of a retailer. A redemption condition 1020 such as that associated with redemption 
code 1010 CI specifies a frequency at which the product must be redeemed or a maximum 
(minimum) time period which may elapse between redemptions. Other possible redemption 
conditions 1020 include, but are not limited to, a requirement to make additional purchases at 
30 a retailer such as an oil change every three months or a convenience store purchase of over 
$5.00, a particular car which must be used to receive an agreement product under an 
agreement, and a maximum retail price of an agreement product during a redemption. The 
customer may also impose a redemption condition 1020 on an agreement, such as specific 
times at which certain family members may redeem gasoline under the agreement. The 
19 
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redemption condition 1020 corresponding to a redemption code 1010 may also specify 
penalties associated with non-flilfillment of a condition, such as a fee, an increase in an 
agreement price, or a decrease in a quantity remaining under an agreement. 

5 Customer Database 

FIG. 1 1 is a tabular representation of a portion of the customer database 11 00 
according to one embodiment of the present invention. The customer database 1 100 stores 
data specific to customers. For example, each record in the customer database 1 100 of FIG. 
1 1 includes data specifying: (i) a name 1110; (ii) a customer identifier 1 120 associated with 
1 0 the name 1110; (iii) a credit card number 1130 provided by the customer which can be used 
to extract payment from the customer; (iv) contact information 1 140 for contacting the 
customer, which may include a telephone number, an e-mail address, a postal address, a 
3 facsimile number, or other information; (v) a subsidy code 1150 identifying a subsidy offer to 

ji which the customer has agreed; and (vi) a bind next offer flag 1 160. The bind next offer flag 

t 1 5 1 1 60 is used to determine whether a next offer submitted by the customer should be accepted, 
y Setting and usage of the bind next offer flag 1 1 60 will be described below. According to 

5 other embodiments, additional data for each record may be stored in the customer database 

1100. 

20 Agreement Database 

3 FIG. 12 is a tabular representation of a portion of the agreement database 1200 

according to one embodiment of the invention. As shown, each record in the agreement 
database 1200 includes several fields, specifying: (i) a redemption identifier 1210; (ii) a 
customer identifier 1220; (iii) a product 1230; (iv) an agreement price 1240; (v) a retailer 

25 identifier 1250; (vi) a quantity remaining 1260; and (vii) a redemption code 1270. 

The data in the agreement database 1200 is used to store and track the details of an 
agreement between a customer and the controller 200. For example, the redemption 
identifier 1210 identifies an agreement, the customer identifier 1220 identifies a customer in 
the customer database 1 100, the product 1230 and the agreement price 1240 specify terms of 

30 the agreement, and the retailer identifier 1250 identifies honoring retailers from the retailer 
database 600. An honoring retailer is a retailer at which a product may be redeemed under a 
particular agreement. The quantity remaining 1260 is decremented based on redemption of 
the product 1230 according to the agreement, and the redemption code 1270 can be used in 
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conjunction with the redemption code 1010 of the redemption condition database 1000 to 
identify a required redemption condition 1020 prior to authorization of a redemption. 

Other fields may also be included in the agreement database 1200. For example, each 
record may include information specifying a vehicle for which gasohne will be purchased 
5 under an agreement, such as a make and model, license plate number, or Vehicle 
Identification Nimiber (VIN). 

Retailer Redemption Database 

FIG. 13 is a tabular representation of a portion of the retailer redemption database 
10 1300. The tabular representation shown contains data for three customers who redeemed 
gasoline at a retailer identified by a retailer identifier 1310 R-OOOl . Of course, the retailer 
redemption database 1300 preferably includes data for additional retailers and additional 
O records for additional customers. For each retailer identified by retailer identifier 1310, the 

ijf retailer redemption database 1300 includes records with several fields, specifying: i) a 

% 15 customer identifier 1320, ii) a product 1330, iii) a quantity redeemed 1340, and iv) a retail 
H price 1350. 

3 More specifically, the customer identifier 1320 identifies a particular customer who 

1, redeemed a product from the retailer 1310, the product 1330 identifies the product redeemed, 

ill the quantity redeemed 1 340 identifies how many units of the product 1330 were redeemed by 
72 20 the customer, and the retail price 1350 identifies a retail price per unit of the product 1330 at 
Q the time the product was redeemed. The data of the retailer redemption database 1 300 is 

used, in some embodiments, to determine how many units remain to be redeemed under an 
agreement, and a settlement amount due to a retailer 1310 after a redemption. The 
determination of remaining units and the settlement process are described in detail below. 

25 

PROCESSES 

FIG. 14 is a flow chart of process steps according to one embodiment of the present 
invention. The process steps may be embodied in hardware, in processor-executable process 
steps stored on a computer-readable medium and executed by a processor, in processor- 
30 executable process steps encoded in an electronic signal received and executed by a 

processor, or in any combination thereof The FIG. 14 process steps may be embodied in the 
customer device 100, the retailer device 300, the customer terminal 400, or in another device. 
The process steps of the other flow charts described herein may be similarly embodied. In 
addition, the particular arrangement of steps in the flow chart of FIG. 14, as well as in the 
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Other flow charts described herein, is not meant to imply a necessary order to the steps; 
embodiments of the present invention can be practiced in many different orders. 

The FIG. 14 process steps describe a process to establish an agreement with a 
customer to provide a number of units of a product for an agreement price, to arrange with a 
5 retailer to have a product redeemed at the retailer, and to receive data indicating a redemption 
of the product. The process steps begin at step 1401, in which an agreement is established 
with a customer to provide a plurality of units of an agreement product to the customer for an 
agreement price. Next, in step 1402, redemption authorization information is provided to a 
retailer based on the agreement. 
10 The redemption authorization information may include a customer identifier, details 

of an agreement estabHshed with a customer, or both. The redemption authorization may also 
include information needed to decrypt an encoded redemption identifier which may be 
O received from a customer. According to one embodiment of step 1402, redemption 
in authorization information is provided from the confroller 200 to the retailer in response to 
S 1 5 reception of a redemption identifier from the retailer. The redemption authorization 
^ information provides details of an agreement between a customer and the confroller 200 
;H corresponding to the redemption identifier. 

'L, In step 1403, data is received indicating a redemption of the product from the retailer. 

W The data may include details of a product redeemed, a quantity redeemed, a retail price at the 

Jl 20 time of redemption, and a payment made by the customer. The data may be received after 
5 each redemption, after all units under an agreement are redeemed, or at periodic intervals 

such as daily or weekly. By virtue of the foregoing process steps, a system is provided in 
which customers' purchasing habits for fractionally-redeemable products can be influenced in 
a retailer's favor and a retailer is provided with indications of future demand. Moreover, a 
25 customer is provided with convenience, protection against price increases, and, in some 
embodiments may also to pay less than a retail price for a product. 

I. Establishment of an Agreement 

FIG. 15 is a detailed flow chart of process steps according to one embodiment of step 
30 1401 . As such, the process steps generally operate to establish an agreement with a customer 
to provide a plurality of units of an agreement product for an agreement price. The process 
steps may be performed by the customer terminal 400, the retailer device 300, the controller 
200, another device in communication therewith, or any combination thereof 
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Initially, in step 1501, contact is established with a customer. In one embodiment, the 
contact is established in step 1501 in response to receipt by the controller 200 of a hypertext 
transfer protocol (HTTP) request for a web page transmitted by the customer device 100 
using the web browser 162. Specifically, the contact is established by providing the 
5 requested web page to the customer device 100. Accordingly, in this embodiment, the 
customer device 100 is any web-enabled customer device, such as a telephone, an internet 
kiosk, a PDA, a web-enabled automobile computer, such as a NAVSTAR system, or the like. 
Of course, the customer may initially contact the controller 200 using any other of the 
customer devices described above with respect to FIGS. 1 A and IB, either over a direct 
1 0 connection or over networks other than the web. 

The controller 200 may also establish contact with the customer in step 1501 without 
having first been contacted by the customer device 100. For example, the controller 200 may 
O transmit an advertisement to a kiosk or an ATM machine in communication therewith which 
IJI is being used by a potential customer. In another embodiment, the customer terminal 400 is 
£ 15 used both to provide a product and to estabhsh contact with a customer. In a case that the 
customer terminal 400 is a gasoline pump, a customer approaching the pump to dispense 
=0 gasoline may be presented with an invitation on the display 440 to establish an agreement to 
:L, purchase a plurahty of units of gasoline for an agreement price. 

kl After step 1 501 , it is determined whether the customer is a new customer in step 

J:t 20 1 502. In one embodiment of step 1 502, the customer is required to either indicate that he is 
E? a new customer or to input a customer identifier. In the embodiment in which the customer 

receives a web page Irom the controller 200, the customer may be questioned in the web page 
as to whether he has previously established an agreement with the controller 200. If the 
customer is a new customer, flow proceeds to step 1503, in which customer information, such 
25 as a customer name, contact information and payment information are received Irom the 
customer. The contact information may include a postal address, a telephone number, an 
email address or the hke, and the payment information may be a credit or debit card number. 
Although a single customer corresponds to each record shown in FIG. 1 1, it should be noted 
that a product may be redeemed under an agreement by more than one particular person, such 
30 as by each member of a family. 

The information received in step 1503 may be entered by the customer into a web 
page, and passed fi-om the web browser 162 executing in the customer device 100 to the 
controller 200 using the Common Gateway Interface (CGI) protocol. In this regard, all data 
transmitted to the controller 200 firom the customer according to the FIG. 15 flow chart and 
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the other flow charts herein may be transmitted using the CGI protocol or another known 
protocol for transmitting data between devices. 

Next, in step 1504, the customer is assigned a unique customer identifier and, in step 
1505, the customer information is stored in association with the assigned customer identifier. 
5 In one example of step 1505, a record is created in the customer database 1 100 for which the 
customer name 1110, customer identifier 1 120, credit card number 1 130 and contact 
information 1 140 fields are populated with the customer name, the assigned customer 
identifier, contact information and payment information received in step 1503, respectively. 
Flow then proceeds fi-om step 1505 to step 1506. 
10 Returning to step 1502, flow continues therefirom to step 1507 in a case that the 

customer is not identified as a new customer. In step 1507, a customer identifier is received 
jfrom the customer and, in step 1 506, an offer is received firom the customer to purchase a 
O number of units of an offer product for an offer price. One embodiment of step 1506 is 
Ijf discussed in detail below with respect to FIG. 1 6. 

£ 1 5 The offer product may be specified generally or specifically in accordance with the 

'===1 invention. In a case that the offer product is gasoHne, the offer product could be, for 

2 example, 87 octane gasohne, 89 octane gasoline, or a product having between 85 and 89 

L octane. The number of units may be specified in any known manner, such as in gallons, tens 

m of gallons, tanks or the like. In one embodiment, the offer also includes preferred retailers or 

20 locations at which the customer would like to redeem the offer product. 
O The offer price may be a specific dollar amount per unit, such as $1 .25 per gallon of 

87 octane gasoline, $50.00 per tank of gasoline, or $12.50 per forty gallons of gasoline. 
However, it should be noted that the offer price may not be a specific dollar amount. Rather, 
the offer price may be presented in terms of a percentage off a retail price (e.g. 15% off the 
25 retail price), a monetary amount off the retail price (e.g. $.10 off the retail price per gallon), 
or a price for a certain retail value ($50 for $60 worth of gasoline). The referenced retail 
price may be a current retail price or a retail price at a time of redemption. 

Rather than receiving an offer price and a quantity in step 1506, the controller 200 
may receive from the customer a price per unit and a period of time during which the price is 
30 effective, thereby locking in a price for the period of time. Also received fi-om the customer 
may be a maximum price he is willing to pay or a number of prices, each corresponding to a 
different agreement product. In another alternative, the controller 200 may receive a before- 
tax offer price. Accordingly, the controller 200 may adjust the before-tax offer price to an 
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after-tax offer price prior to step 1508 depending upon the State in which the gas will be 
redeemed. 

In step 1508, it is determined whether the received offer is acceptable. One 
embodiment of such a determination will be described in detail below with respect to FIG. 
5 1 8. Generally, however, the determination may be based on the offer price, a quantity of the 
product desired or a particular automobile to which the agreement will be applicable, if 
specified by the customer. For example, an offer for an agreement applicable to a minivan 
may be accepted over an identical offer for a small car with excellent fuel economy. In one 
embodiment described below, the controller 200 determines whether to accept an offer 
1 0 without regard to subsidies or settlement agreements with particular retailers. For example, 
the controller 200 may be instructed by the entity operating the controller 200 to accept all 
offers specifying an offer price of over 80% of an average retail price for gasoline. 
O Accordingly, in a case where an average retail price for 87 octane gasoline is $1 .37 per 

|i gallon, the controller 200 accepts all offers for 87 octane gasoline equal to or greater than 
%\5 $ 1 . 1 0 per gallon. On the other hand, the controller 200 may base acceptability primarily 
y upon settlement agreements with participating retailers. For example, the controller 200 may 

l5 have a settlement agreement with a retailer to pay the retailer $1 .30 per gallon for 89 octane 

gasoline. Therefore, the controller 200 accepts all offers for 89 octane gasoline specifying an 
Ul offer price of equal to or greater than $ 1 .30 per gallon. 

\1 20 Acceptability of an offer may also be based on the existence of third party svibsidies. 

2 As an example of this embodiment, a case is considered in which a settlement price to be paid 

to a retailer is $1.45 per gallon for 93 octane gasohne, which also happens to be the current 
retail price offered by the retailer. An offer is received to purchase 100 gallons of gasohne 
for $1.25 per gallon. The offer represents a $20 discount off 100 gallons at the retail price. 
25 However, a long distance carrier has offered to provide the controller 200 a $30 subsidy for 
every customer who agrees to switch to the long distance provider. Accordingly, after 
receiving the offer, the controller 200 asks the customer if he would switch long distance 
service to the long distance provider. If so, the offer will be accepted, since the $30 subsidy 
can be used to make up for the $20 discount and the $10 left firom the $30 can be used by the 
30 controller 200 in any manner. Generally, any type of cross-subsidy offer may be used to 

"bridge the gap" between the settlement price and the agreement price. Detailed discussions 
of cross-subsidy systems are described in U.S. Patent Application Serial No. 09/322,351, 
filed May 28, 1999, for "Method and Apparatus for Providing Cross Benefits and Penalties", 
the contents of which are incorporated by reference herein for all purposes. 
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In other embodiments, offer acceptability is based on retailer-specified criteria. For 
instance, a retailer may have previously indicated to the controller 200 certain parameters on 
which to base acceptance of an offer from a customer. For example, a retailer may indicate 
that it will honor offers for more than 50 gallons of 89 gasoline at more than $1.30 per gallon. 
Accordingly, if a customer submits an offer to purchase 25 gallons of 89 octane gasoline at 
$1.35 per gallon, the offer is not accepted because it specifies an insufficient amount of 
gasoline. 

Offer acceptabihty may also be based on criteria provided by a subsidy provider, hi 
this case, a long distance provider offers to subsidize the difference between an offer price 
and a settlement price if the customer agrees to sign up for a credit card provided by the 
subsidy provider, and if the offer price is no more than $.10 less than the settlement price. 
Accordingly, any offer having an offer price no more than $.10 less than a retail price of an 
offer product is deemed acceptable in step 1508. 

hi another embodiment, the offer is routed to retailers through the retailer devices 
300, 301 and 302 based on information in the retailer database 601 of FIG. 2B. The 
controller 200 may route the offer to retailers one at a time based on a listed priority until one 
retailer accepts the offer and the offer thereby becomes an agreement. In another 
embodiment, the controller 200 routes the offer to several retailers at one time. In a case that 
more than one of the retailers accepts the offer, the first retailer to accept the offer is awarded 
the resulting agreement. Ahematively, each accepting retailer is awarded the agreement, in 
which case the agreement product can be redeemed at each of the accepting retailers for the 
agreement price. For example, if the customer submits an offer to purchase 50 gallons of 87 
octane gasoline and the offer is accepted by three retailers, a first 10 gallons may be 
redeemed at the first retailer, a next 12 gallons at the second retailer, a next 9 gallons 
redeemed at the third retailer, and a last 19 gallons redeemed at the second retailer. 

In another alternative, the customer may have to choose one retailer of the several 
accepting retailers at which he will redeem the product. la this case, the controller 200 
informs the customer which retailers have accepted the offer and the customer selects one of 
the retailers. In one embodiment, the customer is charged a fee for an abiUty to specify more 
than one retailer. Or, the customer may be informed of which retailers have accepted the 
offer and, after redeeming the agreement product firom one of the retailers, the customer may 
be required to continue to redeem the agreement product at the one retailer for the remainder 
of the agreement. 
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In yet another embodiment, the controller 200 informs each of multiple accepting 
retailers that more than one retailer has accepted the customer's offer. The controller 200 
also allows the retailers to present offers to the customer to influence the customer to select a 
particular one of the retailers. As an example, two retailers accept a customer's offer to 
5 purchase 60 gallons of 87 octane gasoline for $1 .30 per gallon. The two retailers are notified 
that more than one retailer has accepted the offer. A first retailer then offers to provide the 
customer with 60 gallons of 89 octane gasoUne for the agreement price, $1 .30 per gallon, and 
the second retailer offers to provide the customer with 60 gallons of 87 octane gasoline for 
$1.25 per gallon. The customer then selects one of the two retailers for redemption of the 
10 product. Alternatively, the customer may redeem the agreement product at either retailer, 
while paying retailer-de fined agreement prices. 

hi another embodiment, the controller 200 selects a retailer from whom the customer 
O will redeem the agreement product. The selection may be performed randomly, or in a way 

m to ensure that certain retailers or certain gasoline manufacturers receive a pre-specified 

% 1 5 percentage of customers. The controller may also select the retailer so as to maximize the 
'2 profits generated by the controller 200, such as by selecting retailers having a lowest 

Q settlement price for a particular agreement. Of course, any combination of the above 

;L, techniques may be used in step 1 508 to determine the acceptability of the received offer, 
y If the offer is not deemed to be acceptable in step 1508, flow proceeds to step 1509, 

il 20 wherein the customer is asked whether he wishes to submit a new offer. If not, the process 
Q steps terminate. If the customer indicates that he wishes to submit a new offer, flow returns 

to step 1506 for reception of an offer from the customer. 

If the offer is deemed to be acceptable in step 1508, the offer becomes an agreement, 
and the controller 200 transmits an agreement confirmation to the customer in step 1510. The 
25 agreement confirmation informs the customer of which offer was accepted, the identity of an 
honoring retailer or retailers, and required payment. In one embodiment, the agreement 
confirmation also includes the details of the agreement (number of units, agreement product 
and agreement price), and instructions for redeeming the agreement product. The agreement 
confirmation may be transmitted back to the customer device 100 which was used to submit 
30 the offer, may be transmitted to the customer by electronic mail, or may be presented to the 
customer by some other means. 

Next, information pertaining to the agreement is stored in the agreement database 
1200 in step 1511. In some embodiments, the customer indicates, after step 1508 and prior to 
step 1511, whether or not he wishes to enter the agreement. According to this embodiment, a 
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customer may refuse to establish an agreement after the controller 200 has determined that 
the received offer is acceptable. However, a retailer may be less likely to accept an offer if 
not guaranteed that the customer will be bound to the offer upon the retailer's acceptance. 
Next, in step 1512, the controller 200 collects a payment from the customer 
5 corresponding to the agreement. In one embodiment, the customer is charged the price of the 
agreement using the payment information received in step 1503. The price may be the 
agreement price, in the case that the agreement specifies 50 gallons of 87 octane gasoline for 
$60.00, or may be an agreement price multipKed by a number of units specified under the 
agreement, in the case that the agreement price is $1.25 per gallon for 50 gallons of 89 octane 
10 gasoline. 

Some agreements according to the present invention expire after a period of time. In 
a case that a customer pre-pays for such an agreement prior to any redemption under the 
= agreement, the customer may receive a credit for any unredeemed quantity after expiration of 

- the agreement. The credit may be in the form of currency, credit usable to pay for subsequent 

1 5 agreements, credit usable to pay for specific items, or the like. The received credit may be 
equal to an agreement price per unit multiplied by the unredeemed quantity minus a fee. By 
providing credit for an unredeemed quantity, this embodiment encourages customers to enter 
into agreements to purchase a number of units of a product over time. 

In other embodiments, the customer pays the price of the agreement in installments 
^ 20 before, during and/or after a specified redemption period. Alternatively, the customer pays 
= the retailer each time the product is redeemed. For example, the customer may redeem a 
number of gallons and then pay the retailer an agreement price per gallon multiplied by the 
number of gallons redeemed, in which case the controller 200 may pay an additional price to 
the retailer according to a settlement price established with the retailer. On the other hand, 
25 the customer may pay the retailer the full retail price for the redeemed number of gallons and 
be reimbursed by the controller 200 for any difference between the retail price and the 
agreement price. Payment may also be received from the customer after the entire quantity 
under the agreement has been redeemed or after a specified amount of time. Details of 
various settlement methods according to the invention are set forth below. 
30 After the payment is successfully collected in step 1 5 12, a redemption identifier 

associated with the agreement is generated and output to the customer in step 1513. The 
redemption identifier 1210 may be based on information provided by the customer, or it may 
be generated by the controller 200. For example, the redemption identifier may simply be the 
credit card number 1 130 associated with the customer. The redemption identifier 1210 is 
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stored in conjunction with other corresponding agreement information in the agreement 
database 1200 so as to allow identification of separate agreements established with a same 
customer. The redemption identifier 1210, as will be described in detail below, can be used 
during redemption to access agreement information corresponding to an agreement or may 
5 itself represent encoded agreement information. 

FIG. 16 is a flow chart of processor-executable process steps according to one 
embodiment of step 1506 of FIG. 15. The process steps may be executed by the controller 
200, the retailer device 300, the customer terminal 400, and a device in communication 
therewith, alone or in combination. 
10 The process steps begin at step 1601, in which product information is received from 

the customer. In one embodiment, the information is input by the customer, using the input 
device 140 of the customer device 100, into a web page transmitted to the customer device 
ill 100 by the controller 200. The input information is then transmitted back to a web server of 

J rJ the controller 200 using the CGI protocol or another protocol for transmitting data from a 
:t 1 5 web client to a web server. Of course, the information may be input using the input device 
SI 430 of the customer terminal 400. The information received in step 1601 specifies an offer 

^fl product, such as Exxon® 87 octane gasoline, 87 octane gasoline, or 86 to 89 octane gasoline. 

=L^^ After the product information is received, information specifying a desired quantity of 

i xj the offer product is received in step 1602. The desired quantity information may be input by 

20 the customer using any of the methods described above with respect to step 1601. In one 
^3 embodiment, the desired quantity information received in step 1602 indicates a desired 

number of tankflils of a particular gasoline product, with an amount of a tankfal being 
defined depending upon a tank size of an automobile specified by the customer. For 
example, in a case that the information received in step 1602 indicates that two tankfiils of 
25 gasoline are desired, the desired quantity is understood to be 50 gallons in a case that the 
customer is establishing an agreement for a sport utility vehicle, or 20 gallons in a case that 
the customer is establishing an agreement for a compact car. A tankfol may be defined 
depending upon a customer's historical average redemption amount or the like. 

Next, in step 1603, retailers are selected based on the information received in steps 
30 1 601 and 1 602. In one embodiment, a postal address or ZIP code of the customer is used to 
identify participating retailers located nearby the customer. The postal address or ZIP code 
may be input by the customer or determined after reception of a customer identifier using a 
database such as the customer database 11 00. Of the identified retailers, those retailers 
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providing the offer product are selected in step 1603. Then, in step 1604, a retail price of the 
offer product is determined for each of the selected retailers. The retail price may be 
determined in step 1604 by reference to the retailer database 600 of the controller 200. 
After determination of the retail prices, a plurality of proposed offer prices are 
5 determined based on the determined retail prices in step 1605. Li one embodiment, the 
plurality of proposed offer prices are determined by determining an average price of the 
determined retail prices and by subtracting pre-specified amounts from the average price. For 
example, in a case where retailer R-OOOl and R-0002 are selected in step 1603, and the offer 
product is 89 octane gasoline, corresponding retail prices (89) 650 of $1.70 per gallon and 
10 $.1 .64 per gallon are retrieved from the retailer database 600. The retail prices are averaged, 
resulting in an average retail price of $1.67 per gallon. Next, subtracted from the average 
retail price are the pre-specified amounts 5 cents, 10 cents, 12 cents and 15 cents, to produce 
^ proposed offer prices of $1.62 per gallon, $1.57 per gallon, $1.55 per gallon, and $1.52 per 
gallon. 

r 15 hi step 1606, an associated acceptance probability is determined for each of the 

plurality of proposed offer prices. An associated acceptance probability corresponds to a 
probability that an associated offer price will be deemed acceptable in step 1508. hi one 
embodiment, an acceptance probability is associated with a pre-specified amoimt less than an 
average retail price, hi this regard, the pre-specified amounts 5 cents, 10 cents, 12 cents and 
20 15 cents may be associated with acceptance probabilities of 98%, 96%, 90% and 80%, 

£ respectively. As a result, associated acceptance probabilities of 98%, 96%, 90% and 80% are 

determined for the proposed offer prices $1 .62, $1 .57, $1 .55 and $1 .52, respectively, in step 
1606. 

In another embodiment, an associated acceptance probability associated with each of 
25 the plurality of the proposed offer prices varies depending upon a customer's previous 
behavior. FIG. 17 illustrates tables 1700 and 1750, in which associated acceptance 
probabilities vary depending on a customer's previous behavior. For example, the table 1700 
illustrates that the acceptance probabiHties 98%, 96%, 90% and 80% are appropriate in a case 
that the controller 200 has previously accepted one offer from the customer. The table 1750, 
30 on the other hand, illustrates that the associated acceptance probability for each proposed 

offer price is 100% if a customer has not yet had an offer accepted by the controller 200. The 
data in the table 1750 is used to ensure that the customer will use the system at least once, 
thereby encouraging fiiture uses of the system. 
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In another example, the associated acceptance probabilities determined for a second 
offer may be greater than those determined for a first offer in a case that the second offer 
price is greater than the first offer price, in order to encourage such offers. Conversely, 
associated acceptance probabihties may be decreased in a case that a customer continually 
5 enters low offer prices, in order to discourage such offers. 

The plurality of proposed offer prices and associated acceptance probabilities are 
transmitted to the customer in step 1 607. In one embodiment, each of the proposed offer 
prices is displayed on the display 140 of the customer device 100 in association with an 
associated acceptance probability in a manner selectable by the customer. Accordingly, a 
10 selected offer price is received from the customer in step 1608. It should be noted that the 
selected offer price according to the FIG. 16 embodiment may be one of the plurality of 
proposed offer prices or another offer price input by the customer. 
O FIG. 18 is a flow chart of process steps according to one embodiment of step 1508. 

in Accordingly, the FIG. 1 8 process steps are used to determine whether the offer received in 
% 15 step 1506 is acceptable. The process steps may be performed by the customer terminal 400, 
• J the retailer device 300, the controller 200, another device in communication therewith, or any 
combination thereof 

Initially, in step 1 801 , it is determined whether the offer meets pre-quaUfication 
y requirements. For example, the offer may be examined to determine whether the ofler price 

20 is too low to be seriously considered. Immediate rejection of such low offers is desirable 
Q because it discourages subsequent submissions of such offers. An offer price may be 

considered too low if it is, for example, more than 20 cents less per gallon than an average 
retail price per gallon of the offer product. 

An offer may also fail to meet pre-qualification requirements in step 1801 if it is 
25 identical to a prior offer given by a same customer within a previous period of time, such as 
one day. This requirement is intended to discourage a customer from discovering a lowest 
acceptable price by slowly increasing an offer price until an offer is accepted. Accordingly, 
an offer may be deemed identical to a previously-rejected offer in step 1801 without regard to 
an offer price. For example, the offer may be deemed identical to a previous offer it if it is 
30 submitted by an identical customer for a substantially identical product and for substantially 
identical retailers. It may also be determined in step 1801 whether the payment identifier 
submitted by the customer in step 1511 is fraudulent, such as a cancelled credit card number 
or a credit card number previously foimd to be unusable by the controller 200. Of course, 
other pre-qualification requirements can be evaluated in step 1801, such as whether the 
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customer submitting the offer already has a certain number of offers outstanding or whether 
the customer is identified as a fraud risk by a third party fi-aud identification service. 

If it is determined in step 1 801 that the pre-qualification requirements are not met, 
flow proceeds to step 1509 and continues as described above. If the requirements are met, it 
5 is determined whether or not to bind the offer in step 1 802. In one embodiment, it is 
determined in step 1802 to bind the offer if the customer has accepted a subsidy offer in 
conjunction with the submission of the offer. In addition, the controller 200 determines to 
bind the offer in step 1802 if a bind next offer flag 1160 corresponding to the customer is set 
to "yes". 

1 0 Acceptance probabihty tables such as those shown in FIG. 17 and discussed above 

with respect to FIG. 16 may also be used to determine whether to bind the received offer in 
step 1 802. For example, in a case that the received offer price was associated with an 
I acceptance probabihty in step 1 606, that acceptance probability can be used in step 1 802 to 
i determine, according to an algorithm incorporating the probability, whether or not to bind the 

\ 15 offer. In one embodiment, the algorithm may return a "maybe", as described in commonly 
assigned co-pending Application Serial No. (WebHouse Tokens). As described in detail 
therein, the customer, upon receiving a "maybe", is provided with an ability to change the 
"maybe" to a "yes" by raising the offer price, by agreeing to a promotion which results in a 
subsidy payment to the controller 200, or by using tokens or other credits previously provided 
20 by the controller 200 or a third party. 

In a case that no such acceptance probability has been associated with the received 
offer prior to step 1802, an acceptance probability can be determined based on the offer price 
using tables such as the tables 1700 and 1750. In this regard, different tables of acceptance 
probabilities may be applicable to different customer segments, such as platinum, gold, silver, 
25 and head of household tables, each having progressively decreasing probabilities. A 

customer score may be used to decide to which customer segment a particular customer is 
assigned. An equation for calculating a customer's score, according to one embodiment, is 
"customer score = X(number of retailers) + Y(total number of accepted gas offers/average 
price level) + Z(number of promotions accepted)", wherein X, Y and Z are weighting factors 
30 which can be adjusted to aher the respective effects of each term on the final customer score. 
In one embodiment, each segment is assigned a particular range of customer scores, and a 
customer is assigned to a segment based on the range in which his customer score falls. 



Patent 99-082 

Express Mail Receipt Number: E1080833938US 

Accordingly, a customer may receive benefits based on purchasing history. Other 
than receiving better probabilities of acceptance, a frequent customer or a customer referring 
others may receive full service instead of self-service gasoline, an octane upgrade, etc. 

If the controller 200 determines in step 1802 not to bind the offer, flow continues to 
5 step 1509. If the controller 200 determines to bind the offer, the offer becomes an agreement, 
and flow proceeds to step 1803 to determine the retailer or retailers who will be bound to 
honor the agreement. 

In one embodiment of step 1803, a manufacturer providing the agreement product is 
identified using a market share database. FIG. 19A illustrates a tabular representation of a 
10 portion of the market share database 1900 according to one embodiment of the invention. As 
shown in FIG. 19 A, associated with each manufacturer 1910 is a percentage target market 
share 1920, a percentage actual market share 1930 and a percentage difference 1940. The 

0 percentage target market share 1 920 specifies a percentage of all bound customers that it is 
desired to have redeem gasoline at a retailer selling gasoline produced by the associated 

■| 15 manufacturer 1910. The percentage target market share 1920 in based on an agreement 
=J between each manufacturer 1910 and the controller 200. For example, the controller 200 

'% may require a manufacturer to pay $1 ,000 per month for each percent of target market share 

1 allotted to the manufacturer. Therefore, in order to guarantee a 25% market share, a 
til manufacturer 1910 pays $25,000 per month to the controller 200. 

m 20 The percentage actual market share 1930 is a statistic determined by the controller 

O 200 based on an actual percentage of all bound customers that redeem gasoline at the 

associated manufacturer 1910, and the percentage difference 1 940 is obtained by subtracting 
the percentage target market share 1920 from the percentage actual market share 1930 of the 
manufacturer 1910. In the example shown in FIG. 19A, the manufacturer "Exxon" is 
25 selected in step 1803 because the associated percentage difference 1940 is less than any other 
percentage difference in the database 1 900. 

Next, a retailer associated with the manufacturer 1910 is selected. FIG. 19B 
illustrates a tabular representation of a portion of a price tier database 1950 used in one 
embodiment of step 1803. In the representation shown, retailer identifiers 1960 and 
30 associated tiers 1970 are stored for a particular manufacturer and a particular product, such as 
Exxon and 89 octane gasoline. In one embodiment, the retailer identifiers 1960 refer to the 
same retailer as the retailer identifiers discussed above with respect to the databases of the 
storage device 260. The tier 1970 corresponding to a retailer identifier 1960 can be 
determined in many ways. 

33 



Patent 99-082 

Express Mail Receipt Number: E1080833938US 

In one embodiment, a standard distribution of retail prices is created for each product 
(e.g. 89 octane gasoline) of the manufacturer (e.g. Exxon), and those retailers selling the 
product for a retail price less than the average retail price minus one standard deviation are 
assigned to the "low" tier 1970, those retailers selling the product for a retail price within one 
5 standard deviation of the average retail price are assigned to the "medium" price tier 1970, 
and those retailers selling the product for a retail price greater than the average retail price 
plus one standard deviation are assigned to the "high" price tier 1970. 

After selection of a manufacturer 1910 from FIG. 19A, a portion of the price tier 
database 1950 corresponding to the manufacturer 1910 and the offer product is accessed to 
10 identify retailers having a lowest price tier 1970. In the example of FIG. 19B, retailers R- 
0001, R-0004 and R-OOlO are selected. Next, one of the three retailers is selected as the 
honoring retailer according to an algorithm providing an equal probability that each of the 
i3 three retailers will be selected. After selection of the honoring retailer, flow continues to step 
I S 1 5 1 0 as described above. 

% 15 Of course, any of the methods described above with respect to step 1508 may be used 

' J to determine whether to bind an offer and to determine an honoring retailer or retailers. 

'L,, II. Product Redemption 

kl FIG. 20 is a flow chart illustrating processor-executable process steps according to 

Tl 20 one aspect of the present invention. It should be noted that several or all of the process steps 
O of FIG. 20 may be performed by the controller 200, the retailer device 300, the customer 

terminal 400, or by another system in communication therewith, such as a system maintained 
by a product manufacturer. 

The FIG. 20 process steps begin at step 2001, in which a redemption request is 
25 received from a customer along with a redemption identifier. The redemption request 

includes a desired quantity of a particular product, so as to allow the retailer to determine 
whether to authorize the requested redemption. 

In one embodiment, the redemption request and the redemption identifier are 
presented by the customer at the customer terminal 400, such as a gasoline pump. In this 
30 regard, the redemption identifier may be encoded in a magnetic strip on a credit card or a 
debit card, and the customer may submit the redemption identifier by swiping the card 
through a card reader in the input device 430 of the offer submission device 402. 

The redemption identifier may also be in the form of a bar code which is transmitted 
from the controller 200 to the customer in step 1510 and then printed out in hardcopy form 
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using the printer 1 50, the printer 450, or the printer 350, depending upon the device from 
which the offer was received in step 1508. In this case, the input device 430 includes a bar 
code reader which reads the bar code to retrieve the redemption identifier. In another 
alternative, a signal encoding the redemption identifier is emitted by a transponder similar to 
5 the one used in the Mobil® Speedpass® program and received by a suitable receiver in the 
input device 430, which extracts the redemption identifier therefi-om. Of course, the 
redemption identifier may also be an alphanumeric code which the customer inputs using a 
keypad of the input device 430. 

In another embodiment, the customer places a telephone call to the controller 200 
10 before a redemption and receives a redemption identifier which is then input to the customer 
terminal 400 to enable the redemption device 401 . The call may also be placed to the offer 
submission device 402. After redemption, the customer terminal 400 outputs a second code 
£^ to the customer which encodes a quantity redeemed, a product redeemed, etc. The customer 
Ln then places another call to the controller 200 and inputs the second code, using which the 

%\S controller 200 updates a record corresponding to the redemption. The customer may be 
^^=1 penalized for not placing the second call by being charged a fee or by being charged a retail 
;£1 price for the quantity redeemed. 

;L, In yet another embodiment, the customer terminal 400 displays a telephone number 

i=y for the controller 200, which the customer dials to begin a redemption. The controller 200 

72 20 recognizes the customer by the number of telephone used by the customer or by a Personal 
Identification Number input by the customer, and retrieves appropriate agreement 
information based thereon. 

Rather than presenting a redemption identifier at the customer terminal 400, the 
redemption identifier may be presented to a cashier at the retailer using a magnetic strip, bar 
25 code, alphanumeric code, or the like. The cashier then uses a card reader, bar code reader, or 
keypad in the input device 330 of the retailer device 300 to input the redemption identifier. It 
should be noted that either the retailer device 300 or the customer terminal 400 may transmit 
the redemption identifier and the redemption request to the controller 200. Accordingly, the 
redemption request and the redemption identifier may be received in step 2001 by at least the 
30 customer terminal 400, the retailer device 300 and the controller 200. 

Agreement information associated with the received redemption identifier is retrieved 
in step 2002. In this regard, the offer submission device 402 may store agreement 
information in a database similar to the agreement database 1200, and may therefore use a 
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received redemption identifier to retrieve associated agreement information from the 
database. Alternatively, the retailer device 300 may store agreement information received 
from the controller 200 in the agreement database 363 and, regardless of whether the offer 
was submitted to the cashier or to the offer submission device 402, the retailer device 300 
5 retrieves the associated agreement information stored therein in step 2002. In another 
embodiment, the redemption identifier received in step 2001 encodes the agreement 
information and the agreement information is retrieved therefrom in step 2002. 

In yet another embodiment, the retailer stores a list of valid redemption identifiers in 
the retailer device 300, the customer terminal 400, or in a central retailer database (e.g. a 
10 central Exxon database with which all Exxon retailers are in communication). If the 

redemption identifier received in step 2001 corresponds to a listed redemption identifier, the 
retailer fransmits the redemption identifier to the controller 200. In response, the controller 
O 200 retrieves agreement information corresponding to the received redemption identifier from 
in the agreement database 1200. Alternatively, the redemption identifier and the redemption 
;;;; 15 request are transmitted from the retailer device 300 or the customer terminal 400 to the 
SJ confroller 200, and the controller 200 retrieves associated agreement information from the 

agreement database 1200 in step 2002. It should be noted that all locally-stored retailer data 
■1^ described herein may be stored in the retailer device 300, the customer terminal 400, and/or a 

111 cenfral retailer database, and that all fransmissions to and fi-om a retailer may be transmitted 
fz 20 to and from the retailer device 300, the customer terminal 400, and/or a cenfral retailer 
O database. 

In step 2003, the requested redemption is authorized. In one embodiment, the 
controller 200 analyzes the retrieved agreement information to determine whether to 
authorize the redemption and transmits a signal authorizing the retailer to provide the 
25 requested redemption. In other embodiments, the retailer device 300 or the customer 

terminal 400 compares the redemption request with the retrieved agreement information to 
determine whether to authorize the redemption. Embodiments of step 2003 will be described 
in more detail below with respect to FIG. 21 . 

Next, in step 2004, the redemption is managed to ensure compliance with the 
30 agreement. In one embodiment of step 2004, the customer terminal 400 controls the 

redemption device 401 to set a price for the agreement product equal to the agreement price. 
According to this embodiment, the customer pays the agreement price to the retailer and the 
controller 200 reimburses the retailer for any difference between the agreement price and a 
settlement price established between the controller 200 and the retailer. The customer 
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terminal 400 may also control the redemption device 401 to ensure that an amount redeemed 
does not exceed a quantity remaining under the agreement. In this regard, the customer 
terminal 400 may control the redemption device 401 to provide a pre-specified amount in 
addition to the quantity remaining. If the customer redeems the pre-specified additional 
amount, the amovmt may be priced at the agreement price, the settlement price, or the retail 
price. 

In other embodiments of step 2004, the customer terminal 400 displays an agreement 
price and a quantity remaining imder the agreement to the customer, and the customer is 
responsible for redeeming an appropriate amount. If the customer redeems more than the 
quantity remaining, the customer may be charged the retail price or the agreement price for 
the additional amount. The customer may also be charged a penalty, such as a flat fee or a 
price greater than the retail price for the additional amount. More specific methods for 
managing the redemption according to step 2004 will be described below. 

Finally, in step 2005, the agreement information is updated based on the redemption. 
If the retailer stores agreement information locally in the agreement database 363 of the 
retailer device 300 or the customer terminal 400, the locally-stored agreement information is 
updated. In a case that the controller 200 keeps an updated record of the agreement in the 
agreement database 1200, the retailer transmits redemption information to the controller 200 
which allows the controller 200 to perform such an update, such as an indication of redeemed 
product, the quantity redeemed, a retail price of the redeemed product, and/or a quantity 
remaining under the agreement. In one embodiment, the controller 200 also communicates 
with the retailer devices 301 and 302 and/or the customer terminals 410 and 420 to update 
corresponding agreement information which is locally stored in the retailer devices 301 and 
302 and/or the customer terminals 410 and 420. The latter embodiment ensures that each 
retailer honoring an agreement has updated agreement information stored locally. Specific 
embodiments for updating the agreement information in step 2005 will be discussed below. 

FIG. 21 is a flow chart of processor-executable process steps to determine whether to 
authorize a requested redemption according to one embodiment of step 2003. The process 
steps may be performed by the retailer device 300, the customer terminal 400, the controller 
200, a device in communication therewith, or by any combination thereof. 

Initially, in step 2101, it is determined whether the redemption identifier received in 
step 2001 is valid at the retailer receiving the redemption identifier. In a case that step 2101 
is performed by the controller 200, the agreement database 1200 is checked to see if the 
retailer is identified by a retailer identifier 1250 corresponding to the received redemption 
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identifier 1210. In a case that step 2101 is performed by a retailer storing agreement 
information for agreements which can be redeemed at the retailer, it is determined whether 
the stored information includes agreement information corresponding to the received 
redemption identifier. If the agreement corresponding to the received redemption identifier is 
5 not redeemable at the retailer, flow proceeds to step 2102 in which data is transmitted 

indicating that the redemption is unauthorized. Thereafter, a customer may be presented with 
a "redemption unauthorized" message or a similar message by the display 440 of the 
customer terminal 400, and/or directed to the retailer or retailers identified by the retailer 
identifier 1250 at which the agreement corresponding to the received redemption identifier 
10 1 2 1 0 can be redeemed. 

If the received redemption identifier is determined to be valid at the retailer, it is 
determined in step 2103 whether a quantity remaining under the agreement is greater than a 
O quantity specified in the redemption request received in step 2001. The determination in step 
; ri 21 03 may be accomphshed by referring to the quantity remaining 1260 corresponding to the 
;E 1 5 received redemption identifier 1 2 1 0 in the agreement database 1 200 or by reference to 
\l corresponding agreement information stored locally at the retailer. For example, in a case 

.^^ that the customer requests 30 gallons of 92 octane gasoline from retailer R-0003, it is 

determined in step 2103 that the redemption cannot be authorized because a corresponding 
h| quantity remaining 1260 in the agreement database 1200 is 25 gallons. Accordingly, flow 
20 proceeds to step 2102. Alternatively, the customer may be invited to resubmit the request 
Q with a reduced quantity. However, if the quantity remaining 1260 under the agreement is 
greater than the requested quantity, flow continues to step 2104. 

In step 2104, it is determined whether any redemption conditions associated with the 
agreement are satisfied. For example, the agreement identified in the agreement database 
25 1200 by the redemption identifier 1210 RED 0024 is associated with the redemption code 

1270 "C2". Therefore, if the redemption identifier 1210 RED 0024 is received in step 2001, 
it is determined in one embodiment of step 2104 whether the current day is a weekday and 
the current time is between 2:00 p.m. and 4:00 p.m., as required by the condition 1020 
corresponding to the redemption code 1010 C2. 
30 If the condition associated with the received redemption identifier is not satisfied, 

flow returns to step 2102 to indicate to the customer that the redemption is unauthorized. If 
the condition is satisfied, data is transmitted in step 2105 indicating that the redemption is 
authorized. The data may be transmitted fi-om the retailer device 300 to the redemption 
device 401, from the controller 200 directly to the redemption device 401, firom the controller 
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200 to the retailer device 300, or from the offer submission device 402 to the redemption 
device 401 . An indication that the redemption is authorized may or may not be transmitted to 
the customer in step 2105. 

FIG. 22 is a flow chart of processor-executable process steps according to one 
5 embodiment of step 2004. In this regard, after a redemption has been authorized in step 

2003, the redemption device 401 is set to dispense the agreement product in step 2201. In the 
case of the agreement identified by the redemption identifier 1210 RED 0024, the redemption 
device 401 is set to dispense 87 octane gasoline in step 2201 . It should be noted that step 
2201, as well as the other process steps of FIG. 22, may be performed by the retailer device 
10 300, the offer submission device 402, or the controller 200, or another device in 
communication with the redemption device 401. 

Next, in step 2202, the redemption device 401 is set to stop dispensing the agreement 
1^ product when the quantity redeemed is equal to the quantity remaining under the agreement. 

Again considering the redemption identifier 1210 RED 0024, the redemption device 401 is 
_ 15 set in step 2202 to stop once three gallons of gasoline have been redeemed. In another 

embodiment, the redemption device 401 is set in step 2202 to stop dispensing the product 
once the total price of the product redeemed reaches a total retail price of the quantity 
remaining 1260 corresponding to the agreement. After step 2202, the customer controls the 
redemption device 401 so as to redeem the agreement product. Once the customer has 
20 redeemed a desired quantity, which may be less than the amount set in step 2202, the quantity 
^ redeemed is received in step 2203. 

In one embodiment of step 2203, the quantity redeemed is received by the retailer 
device 300 and is then transmitted to the controller 200. The quantity redeemed is used, in 
step 2204, to update the agreement information in the agreement database 1200 and in any 
25 local databases used by the retailer. For example, in a case that the customer redeems two 
gallons under the agreement RED 0024, an indication thereof is transmitted to the controller 
200 and the associated quantity remaining 1260 is changed to one gallon 

FIGS. 23 A and 23B illustrate a flow chart of processor-executable process steps of a 
specific embodiment of the FIG. 20 process steps. The process steps relate to an embodiment 
30 in which a customer has prepaid for an entire agreement quantity prior to redemption of an 
agreement product. 

The process steps begin at step 2301, in which a redemption identifier and a product 
selection are received from a customer. For example, the product selection may be received 
in step 2301 by the customer terminal 400 or the retailer device 300 after the customer 
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presses a button located on the offer submission device 402 labeled "87 octane". Next, in 
step 2302, it is determined whether the selected product is a qualifying agreement product 
corresponding to the received redemption identifier. The determination in step 2302 can be 
made by the retailer device 300 or the customer terminal 400 if the agreement information is 
5 stored locally. The determination can also be made by the controller 200 with reference to 
the agreement database 1200. For example, in a case that the received redemption identifier 
is RED 0024, the controller 200 determines in step 2302 whether the selected product is 87 
octane gasoline, since the agreement product 1230 under the agreement identified by RED 
0024 is 87 octane gasoline. 

10 If the selected product is not a qualifying agreement product, flow continues to step 

2303, wherein the redemption device 401 is disabled and a message is presented to the 
customer such as "Please select the correct product", along with an indication of the 
: agreement product. Li one example of step 2303, the offer submission device 402 displays 

the message to the customer. 

15 If the selected product is a qualifying agreement product, the customer is not 

prevented fi"om redeeming the selected product. Accordingly, after the customer begins 
redeeming the product using the redemption device 401 , real-time information regarding the 
quantity of the product redeemed is received in step 2304. Next, in step 2305, it is 
determined whether the redeemed quantity is equal to the quantity remaining under the 

20 agreement. The determination in step 2305 can be made with reference to agreement 
z; information stored in the retailer device 300, the customer terminal 400, or in the quantity 

remaining field 1260 of the agreement database 1200. 

If the redeemed quantity is not equal to the quantity remaining, flow continues to step 
2306. It is determined in step 2306 whether the redemption of the product by the customer is 

25 complete. A redemption may be deemed complete upon detection of a return of a dispensing 
nozzle of the redemption device 401 to its storage space or based on an indication from the 
customer using the offer submission device 402. If the redemption is not deemed complete, 
flow returns to step 2304 for reception of additional real-time information. 

Accordingly, flow continues through steps 2304, 2305 and 2306 until the redemption 

30 is complete or until the quantity redeemed is equal to the quantity which was remaining under 
the agreement prior to the current redemption, whichever occurs first. If the redemption is 
completed first (the determination in step 2306 is "yes"), the agreement information 
associated with the redemption is updated in step 2307. For example, if the quantity 
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redeemed during the redemption is two gallons, the quantity remaining 1260 corresponding 
to the redemption identifier 1210 RED 0024 is updated from three gallons to one gallon. 

If the redeemed quantity is equal to the quantity remaining under the agreement, flow 
proceeds from step 2305 to step 2308. The redemption device 401 is disabled in step 2308 so 
5 that an additional quantity of the agreement product cannot be redeemed therefrom. As a 
result, after step 2308, the quantity so far redeemed is equal to the quantity which was 
remaining under the agreement prior to the redemption. Next, in step 2309, it is determined 
whether the customer would like to receive an additional quantity of the agreement product, 
fri one embodiment of step 2309, the retailer device 300 transmits a message displayed by the 
10 offer submission device 402 such as "Continue pumping 87 octane?", and awaits customer 
selection of a "Yes" or "No" button on the offer submission device 402. Of course, in a case 
that the FIG. 23A process steps are executed by the offer submission device 402, the offer 
submission device 402 generates the message and awaits the customer selection in step 2309. 

rlJ If the customer does not request an additional quantity of the product, flow proceeds to step 

j 15 2307 as described above. 

SJ If the customer requests an additional quantity, it is determined in step 2310 whether 

% the customer requests an extension of the agreement under which the redemption was 

- provided. For example, the customer is asked in step 2310 whether he would like to add an 

1 =j additional quantity of the agreement product to the agreement. If so, the desired additional 

20 quantity is received from the customer and the customer is charged the agreement price for 
Q the additional quantity in step 2311. In one example, a customer redeeming a product under 
the agreement identified by the redemption identifier 1210 RED 0024 requests an extension 
of the agreement in step 2310, transmits a desired quantity such as 20 gallons, and is charged 
the agreement price ($1.45 per gallon)(20 gallons) = $29.00 in step 231 1. The $29.00 is 
25 charged to the corresponding customer using a corresponding credit card number 1 130 

accessed using the customer identifier 1 1 20 and the customer database 1 1 00. In step 2312, 
the desired additional quantity is added to the quantity remaining 1260 corresponding to the 
subject agreement. Flow then returns to step 2304 as described above. 

It should be noted that the customer may also add an additional desired quantity to an 
30 agreement prior to or after a redemption under the agreement. In this regard, the customer 
may receive a message at the customer terminal 400 encouraging the customer to add an 
additional quantity to an agreement. The message may specify a bonus, such as $10 off an 
oil change, which will be awarded to the customer in return for adding 50 gallons to an 
existing product agreement. 
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If the customer does not request an extension of the agreement in step 2310, a form of 
payment is received in step 2313. For example, the customer may submit a credit card 
number to the offer submission device 402 in step 2313. The submitted credit card number 
may be the same as or different from the credit card nixmber using which the customer was 
5 originally charged for the agreement. Any other acceptable form of payment may also be 
received from the customer in step 2313. After the form of payment is received, the 
redemption device 401 is enabled in step 2314. 

Flow pauses at step 2314 until it is determined in step 2315 that the customer 
redemption is complete. Thereafter, in step 2316, the customer is charged, using the form of 
10 payment received in step 2313, the retail price for the difference between the quantity 

remaining 1260 vmder the agreement prior to the redemption and the total quantity redeemed 
during the redemption. For example, if the quantity remaining 1260 under the agreement 
ij prior to the redemption was three gallons and the total quantity of gasoline dispensed during 

the redemption was ten gallons, the customer is charged the retail price per gallon multiplied 
15 by seven gallons. Finally, in step 23 1 7, the agreement information corresponding to the 
agreement is updated by setting the associated quantity remaining 1260 to zero gallons. 
= In another embodiment, the customer is charged in step 2316 a short time after the 

redemption, in order to give the customer the opportunity to establish a subsequent 
agreement. If another agreement is established, the customer is not charged in step 2316 for 
20 the additional quantity redeemed. Rather, the additional quantity is deducted from the 
i quantity specified in the subsequent agreement. 

In another embodiment, if a customer redeems a number of gallons in addition to 
those than available imder an agreement, the customer is charged the agreement price for a 
specified number of the additional gallons, and is charged the retail price for any remaining 
25 gallons. For example, in a case that a customer 

FIGS. 24A and 24B illustrate a flow chart of processor-executable process steps to 
redeem a product under an agreement in accordance with another embodiment of the present 
invention. Generally, the process steps can be used to control the redemption device 401 by 
tracking a retail price of an amount of gasoline redeemed from the redemption device 401. 
30 The process steps may be executed by the offer submission device 402, the controller 200, 
the retailer device 300, a device in communication therewith, or by any combination thereof 

Steps 2401 to 2403 proceed similarly to steps 2301 to 2303 of FIG. 23 A, and 
descriptions thereof are omitted for the sake of brevity. In this regard, flow proceeds to step 
2404 if it is determined in step 2402 that the selected product received in step 2401 is a 



Patent 99-082 

Express Mail Receipt Number: E1080833938US 

qualifying product under the agreement, which is identified using the redemption identifier 
also received in step 2401. 

The total retail price of the quantity remaining 1260 under the agreement is calculated 
in step 2404. hi one embodiment, a current retail price of the selected product is initially 
5 identified in step 2404 using the retailer database 600. For example, in a case that the retailer 
at which the redemption is to occur is the retailer corresponding to the retailer identifier 610 
R-0002 and the selected product is 87 octane gasoline, a retail price of $1.50 per gallon is 
identified according to the data shown in FIG. 6. Next, the quantity remaining 1260 imder 
the agreement is identified using the agreement database 1200. For the agreement 
10 corresponding to the redemption identifier 1210 RED 0024, the quantity remaining 1260 is 
three gallons. Accordingly, the total retail price of the quantity remaining 1260 under the 
agreement is calculated as ($1.50 per gallon)(3 gallons) = $4.50, 
O Next, as the customer redeems the selected product, a total retail price of a redeemed 

ifi quantity is received in step 2405. In one embodiment of step 2405, the offer submission 
;|: 1 5 device 402 monitors the total retail price of the quantity redeemed using the redemption 
=-J device 401 . It is then determined in step 2406 whether the total retail price of the quantity 
redeemed is less than the total retail price calculated in step 2404. If so, it is determined in 
step 2407 whether the redemption is complete, and, if the redemption is not complete, flow 
hj returns to step 2405. As a result, the process steps cycle through steps 2405, 2406, and 2407 
5 T 20 during redemption of the product imtil either the redemption is complete or until the total 
?□ retail price of the quantity redeemed equals the total retail price of the quantity remaining 
under the agreement prior to the redemption. 

If it is determined in step 2407 that the redemption is complete, the quantity redeemed 
is determined by dividing the total retail price of the quantity redeemed by the unit retail price 
25 for the product in step 2410. In one example, the total retail price of a quantity of 87 octane 
gasoline redeemed at the retailer corresponding to the retailer identifier R-0002 under the 
agreement identified by the redemption identifier 1210 RED 0024 is $3.00. According to the 
retailer database 600, the retail price (87) 640 at the retailer identified by the retailer identifier 
610 R-0002 is $1.50 per gallon. Therefore, in step 2410, the quantity redeemed is determined 
30 to be ($3.00)/($l .50) = two gallons. 

The agreement information corresponding to the redemption is updated in step 241 1. 
Using the foregoing example, the agreement quantity 1 260 corresponding to the redemption 
identifier 1210 RED-0024 is decremented by two gallons, to reflect one gallon remaining 
under the agreement. 
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Returning to step 2406, if it is determined that the total retail price of the quantity 
redeemed equals the total retail price of the quantity remaining under the agreement, the 
redemption device 401 is disabled in step 2408. Next, in step 2409, it is determined whether 
the customer requests an additional quantity of the agreement product. If not, the quantity 
5 redeemed is determined by dividing the total retail price of the quantity redeemed by the unit 
retail price for the product in step 2410. For example, at step 2410, the total retail price of a 
quantity of 87 octane gasoline redeemed at the retailer identified by the retailer identifier 610 
R-0002 under the agreement identified by the redemption identifier 1210 RED 0024 is $4.50. 
Again, the retail price (87) 640 for the product at the retailer identified by the retailer 
10 identifier 610 R-0002 is $1.50 per gallon. Therefore, in step 2410, the quantity redeemed is 
determined to be ($4.50)/($1.50) = three gallons. 

The agreement information corresponding to the redemption is updated in step 2411. 
fa Using the foregoing example, the agreement quantity 1260 corresponding to the redemption 
identifier 1210 RED-0024 is decremented by three gallons, to reflect zero gallons remaining 
=t^ 1 5 under the agreement. 

*y Returning to step 2409, flow proceeds therefi-om to step 2412 in a case that the 

, customer requests an additional quantity in step 2409. In step 2412, it is determined whether 

the customer requests an extension of the agreement on which the current redemption is 
U based. As described with respect to step 23 10 of FIG. 23B, the offer submission device 402 
20 may present the customer with an inquiry regarding extension of the agreement, which may 
O be answered by the customer by pressing "Yes" or "No" on a keypad of the offer submission 

device 402. 

If the customer requests an extension of the product agreement, a desired additional 
quantity of the product is received and the customer is charged the agreement price for the 

25 additional quantity in step 241 3, as described with respect to step 23 1 1 . Next, in step 2414, 
the additional quantity is added to the quantity remaining 1260 corresponding to the subject 
agreement as described with respect to step 2312. The process steps then proceed from step 
2414 to step 2404 and continue as described above. 

If the customer does not request an extension of the agreement in step 2412, a form of 

30 payment is received in step 2416. The form of payment may be any payment acceptable to 
the retailer, including the credit card number 1 130 associated with the customer in the 
customer database 1 100. The redemption device 401 is then enabled in step 2417 and flow 
cycles through step 241 8 until it is determined that the redemption is complete. 
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In one embodiment, it is determined in step 2418 that the redemption is complete 
upon detecting that the customer has returned a nozzle of the redemption device 401 to its 
storage area in the redemption device 401. After step 2418, the customer is charged for a 
difference between the total retail price for the quantity remaining under the agreement as 
5 calculated in step 2404 and the total retail price of the entire quantity redeemed. In one 

example, data is received from the customer terminal 400 in step 2419 indicating that $11. 90 
worth of gasoline was redeemed during the redemption. Since the total retail price of the 
quantity remaining 1260 under the agreement prior to the redemption was $4.50, the 
difference charged to the customer in step 2419 is $7.40. The amount is charged to the 
1 0 customer using the form of payment received in step 241 6. 

Lastly, in step 2420, agreement information corresponding to the subject agreement is 
updated. In one embodiment, the agreement information is updated by setting the associated 
=3 quantity remaining 1260 in the agreement database 1200 to zero. The agreement information 
]l may be updated in step 2420 each night by sending redemption information firom the 
:t: 15 customer terminal 400 or the retailer device 300 to the controller 200, may be updated 
-J immediately in local databases stored in the customer terminal 400 or the retailer device 300, 
or may be updated in other manners. For example, information indicating the redemption of 
a particular quantity of a product is transmitted to the controller 200 from the retailer from 
whom the product was redeemed. The controller 200 updates the agreement database 1200 in 
=^ 20 accordance with the received information and transmits information indicating the quantity 
O redeemed to other honoring retailers from which the customer may redeem the product under 
the agreement. According to this example, the other honoring retailers can update their own 
locally-stored information corresponding to the agreement. 

FIGS. 25A and 25B illustrate a flow chart of processor-executable process steps for 
25 performing steps 2003, 2004 and 2005 of FIG. 20 according to one embodiment of the 
present invention. Generally, the FIG. 25A and FIG. 25B process steps are used in an 
embodiment in which agreement information is encoded in a redemption identifier provided 
to the customer. The FIG. 25 process steps may be performed by the customer terminal 400, 
the retailer device 300, the controller 200, another device in communication therewith, or by 
30 any combination thereof 

The process steps begin at step 2501, in which a redemption identifier is received 
from the customer. According to the FIG. 25A and FIG. 25B process steps, the redemption 
identifier received in step 2501 encodes agreement information corresponding to an 
agreement established between the customer and the controller 200. As described above, the 
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redemption identifier may be encoded using known methods for encoding information, such 
as an encryption algorithm having a corresponding decryption algorithm. The redemption 
identifier is provided to the customer after an agreement is established with the controller 200 
and may be embedded in a smart card, a bar code, an electronic signal transmitted by a 
5 transponder, an analog or digital signal transmitted by a PDA, or any other means for 

conveying data. Of course, the offer submission device 402 provides an appropriate interface 
to receive the redemption identifier depending upon the type of redemption identifier 
provided to the customer by the controller 200. 

The redemption identifier is decoded to retrieve agreement information in step 2502. 
10 In one embodiment, the redemption identifier encodes all agreement information needed to 
authorize and manage a redemption and to update agreement information after the 
redemption. For example, the redemption identifier may be decoded using a decryption 
o algorithm corresponding to the encryption algorithm used to encode the redemption identifier 

to produce agreement information such as that shown in the FIG. 12 representation of the 
\5 agreement database 1200. It should be noted that the redemption identifier is decoded in step 
y 2502 using a method corresponding to whatever method was used to encode the redemption 

% identifier. 

^ _ In step 2503, it is determined whether redemption conditions are associated with the 

Ij agreement based on the retrieved agreement information. If so, it is determined in step 2504 

fl 20 whether the associated conditions are satisfied by the current redemption. For example, in a 
O case that the agreement information retrieved in step 2502 indicates that the product can be 

redeemed only between 2:00 p.m. and 4:00 p.m. on weekdays, flow proceeds fi"om step 2503 

to step 2504, in which it is determined whether the current date and time satisfies the 

condition. If not, the customer is informed in step 2505 that the redemption is invalid. For 
25 example, the offer submission device 402 may display a message such as "Redemption 

conditions not satisfied, redemption invalid." 

If it is determined that all conditions associated with the received agreement 

information are satisfied, the customer is informed that the redemption is vahd in step 2506. 

Step 2506 may be performed by displaying a message on the display 440 of the offer 
30 submission device 402 such as "Begin pumping". It should be noted that if no redemption 

conditions are associated with the agreement, flow proceeds fi-om step 2503 directly to step 

2506. 

After step 2506, the redemption device 401 is set to dispense the agreement product in 
step 2507. The identity of the agreement product is determined fi-om the agreement 
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information retrieved in step 2502. In a case that the FIG. 25A and FIG. 25B process steps 
are embodied in the offer submission device 402 and the agreement product retrieved in step 
2502 is 87 octane gasohne, the offer submission device 402 sets the redemption device 401 to 
dispense 87 octane gasoHne in step 2507. Next, in step 2508, the retrieved agreement 
5 information is analyzed to determine a quantity remaining under the agreement. 

The quantity remaining which is determined in step 2508 is equivalent to the quantity 
remaining 1260 shown in the agreement database 1200. For example, in a case that the 
retrieved agreement information indicates that eight gallons of 87 octane gasoline remain to 
be redeemed under the agreement, eight gallons are determined to be the quantity remaining 
10 in step 2508. Accordingly, in step 2509, the redemption device 401 is set to stop dispensing 
gasoline once the redeemed quantity is equal to the quantity remaining determined in step 
2508. In the present example, the redemption device 401 is set to stop dispensing gasoline 
O after eight gallons have been dispensed. Thereafter, in step 25 1 0, an indication is received 

III that the redemption device 401 has stopped dispensing the product. It should be understood 
% 15 that, in view of step 2509, the indication is received in step 2510 if the quantity remaining 
under the agreement has been redeemed, if the customer has manually stopped the 
redemption device 401 prior to redeeming the quantity remaining under the agreement, or if 
^L,, the redemption device 401 automatically stopped after detecting a full gas tank using a nozzle 
l=y sensor. 

=11 20 In step 251 1, data is received indicating the quantity of the product redeemed. As 

1^ described above, the received data may indicate that the quantity remaining under the 

agreement was redeemed, or that a lesser quantity was redeemed. Next, in step 2512, the 
quantity redeemed is subtracted from the quantity remaining imder the agreement prior to the 
redemption. For example, if the quantity remaining under the agreement prior to the 
25 redemption was three gallons and two gallons were redeemed, the difference obtained in the 
step 2512 is one gallon. If the difference is determined to be zero in step 2513, the FIG. 25 A 
and FIG. 25B process steps terminate, since a difference of zero indicates that the customer 
redeemed the entire quantity remaining under the agreement prior to the redemption. 

If the difference is not equal to zero, the quantity remaining under the agreement is set 
30 equal to the difference in step 25 14. Using the previous example, the quantity remaining is 
set in step 2514 to equal (three gallons) - (two gallons) = one gallon. Next, in step 2515, the 
new quantity remaining and other agreement information is encoded into a new redemption 
identifier using an encryption algorithm. The other agreement information encoded into the 
new redemption identifier is, in one embodiment, the information retrieved in step 2502, with 
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the exception of the information specifying the quantity remaining, which is updated with the 
new quantity remaining. Finally, the new redemption identifier is output to the customer in 
step 2516, so as to allow the customer to redeem up to the new quantity remaining under the 
agreement in a subsequent redemption. 
5 The FIG. 25 A and FIG. 25B process steps advantageously allow fractional 

redemption of a product under an agreement without referring to information stored in a 
database local to a retailer or stored in a controller 200. That is, all of the agreement 
information needed to authorize and manage the redemption and to update the agreement 
information is provided in the redemption identifier itself 

10 

III. Settlement 

FIG. 26 is a flow chart of processor-executable process steps for settlement of 
accounts between the controller 200 and a retailer in accordance with one embodiment of the 
present invention. According to one embodiment, the process steps are executed by the 
= 15 controller 200 and/or by a device in communication therewith. 

A redemption record is received fi-om a retailer in step 2601 . The redemption record 
may be received from the retailer device 300, the customer terminal 400, or another device in 
communication therewith. The redemption record, in one embodiment, includes a customer 
identifier and data indicating a quantity redeemed. The redemption record may also include 
20 an identifier identifying the product redeemed, a retail price for the product at the time of 

redemption, a date and time of the redemption, and any other information associated with the 
redemption. Another way of determining a retail price of a product at a time of redemption is 
to receive the date and time of redemption and to determine the retail price at the date and 
time from retailer records. 
25 Next, in step 2602, a settlement price corresponding to the retailer is retrieved. In one 

embodiment, the settlement price is determined using the retailer settlement database 800. 
Specifically, a retailer identifier 810 corresponding to the retailer from which the redemption 
record was received is used to retrieve a settlement price 820 associated with the retailer. 
Next, in step 2603, a settlement due to the retailer is determined based on the received 
30 quantity redeemed and the retrieved settlement price. 

As an example of one embodiment of the FIG. 26 process steps, it is assumed that a 
redemption record received in step 2601 indicates that three gallons of 89 octane gasoline 
were redeemed by a customer at the retailer identified by the retailer identifier 610 R-0001. 
The record also indicates that, at the time of the redemption, the retail price of 89 octane 
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gasoline at the retailer was $1.70 per gallon. According to the retailer settlement database 
800, the settlement price 820 corresponding to the retailer identified by the retailer identifier 
610 R-OOOl is the retail price at the time of redemption. Therefore, the settlement determined 
in step 2603 is equal to the number of gallons redeemed multiplied by the retail price (three 
5 gallons)($ 1 .70 per gallon) = $5.10. In the present example, it is assumed that the customer 
pays for the entire agreement at the time the agreement is established. Of course, the 
determination in step 2603 will vary based on whether the customer pays the entire price for 
the agreement prior to redemption, pays the retailer the agreement price for a quantity 
redeemed after each redemption, or pays the retailer the retail price of a quantity redeemed 

10 after each redemption. In the latter case, the controller 200 pays to the customer the 

difference between the retail price for the quantity redeemed and the agreement price for the 
quantity redeemed, and no settlement amount is paid to the retailer. 

FIGS. 27A and 27B illustrate a flow chart of processor-executable process steps 
according to one embodiment of the FIG. 26 process steps. More specifically, the FIG. 27A 

15 and FIG. 27B process steps relate to a system in which the controller 200 settles accounts 

with a retailer once per day. The process steps may be executed by the controller 200 and/or 
by a device in communication therewith. 

The settlement process of FIG. 27A and FIG. 27B is for use with an embodiment in 
which a customer pays for a total price of an agreement prior to redemption and does not pay 

20 any amount to a retailer from whom a product is redeemed. For example, the settlement 

process of FIG. 27 A and FIG. 27B is used for an agreement in which a customer pays $50.00 
for fifty gallons of 87 octane gasoline at $1.00 per gallon, and does not make any payment to 
a retailer before or after redeeming gasoline fi-om the retailer. Accordingly, the process steps 
of FIG. 27A and FIG. 27B are used to insure payment to a retailer of a settlement price 

25 agreed upon between the retailer and the controller 200. 

The process steps begin at step 2701, in which redemption information is received 
firom a retailer. According to the embodiment of the FIG. 27A and FIG. 27B process steps, 
the redemption information is received from the retailer device 300 after redemption of a 
quantity of gasoline from the retailer. Of course, according to other embodiments, the 

30 redemption information is received at specified intervals throughout a day, or from other 
sources, such as the customer terminal 400. The redemption inforaiation received in step 
2701 includes a customer identifier, a product redeemed, a quantity redeemed, and a retail 
price for the redeemed product at the time of redemption. Next, in step 2702, retailer 
information corresponding to the received redemption information is updated. 
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To explain step 2702, FIG. 13 shows the retailer redemption database 1300 for the 
retailer identified by the retailer identifier 1310 R-OOOl . In a case that information is 
received in step 2701 indicating that the customer associated with the customer identifier 
1320 CUST 888 redeemed 15 gallons of 87 octane gasoline from the retailer, the information 
5 is stored as a customer identifier 1 320, a product 1330, and a quantity redeemed 1 340 

corresponding to one record. In a case that a retail price for 87 octane gasoline at the time of 
redemption was also received in step 2701, the retail price is stored as an associated retail 
price 1350. In another embodiment, the retailer redemption database 1300 does not include 
separate records for each customer identifier 1320. Rather, stored in the retailer redemption 

10 database 1300 are only the product 1330, the quantity redeemed 1340, and the retail price 
1350 at the time of redemption. 

After step 2702, it is determined in step 2703 whether the current time is midnight. If 
not, it is determined in step 2704 whether another redemption has taken place at the retailer. 
If not, flow returns to step 2703. Accordingly, flow cycles between steps 2703 and 2704 

1 5 until either the current time reaches midnight or another redemption takes place at the 

retailer. In a case that another redemption takes place at the retailer before the current time 
reaches midnight, flow returns to step 2701 to receive redemption information for the another 
redemption. 

The determination in step 2703 is related to a pre-established settlement schedule 830 
20 between the controller 200 and a particular retailer. For example, if the settlement schedule 
830 calls for settlement with the retailer after each redemption, flow proceeds directly from 
step 2702 to step 2705. Accordingly, steps 2703 and 2704 can be altered to comport with a 
particular settlement schedule 830. 

Returning to the flow chart, flow proceeds from step 2703 to step 2705 once the 
25 current time reaches midnight. At this point, redemption information has been collected from 
the retailer for a 24 hour interval from midnight of the previous day to midnight of the 
present day. In step 2705, retailer redemption information for a first customer is retrieved. 
For example, retailer redemption information for a first customer may be retrieved from the 
retailer redemption database 1300. With regard to FIG. 13, retailer redemption information 
30 for the customer corresponding to the customer identifier 1320 CUST 888 is retrieved in step 
2705. Next, in step 2706, the quantity redeemed by the customer from the retailer and the 
corresponding retail price at the time of the redemption is determined from the received 
redemption information. In the present example, the quantity redeemed is fifteen gallons and 
the corresponding retail price is $1.50 per gallon. 
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The settlement amount due to the retailer is determined in step 2707. In one 
embodiment, the settlement amount due to the retailer is determined from the retailer 
settlement database 800. As shown in FIG. 8, the settlement price 820 corresponding to the 
retailer identified by the retailer identifier 810 R-OOOl is the retail price. Accordingly, and 
5 since the retail price 1350 is $1 .50 per gallon, the settlement amount is determined in step 
2707 to be (fifteen gallons)($1.50 per gallon) = $22.50. The determined settlement amount is 
added to the total settlement due to the retailer in step 2708. Li the present example, the total 
settlement after 2708 is equal to $22.50. 

If it is determined in step 2709 that redemption information for additional customers 
10 was received, flow returns to step 2705 to calculate the settlement amount due to the retailer 
for each of the additional customers. Once the settlement amount for each additional 
customer is determined and added to the total settlement in step 2708, flow continues to step 
Q 2710, wherein the retailer is paid the total settlement. In the example shown in FIG. 13, the 
1^ total settlement corresponding to the three customers shown is $22.50 + $33.00 + $13.13 = 
;| 15 $68.63. 

After step 2710, the retailer redemption information is initialized in step 271 1 . In 
other words, the data in the retailer redemption database 1300 is cleared because the retailer 
=1^ redemption received for the past 24 hours is not relevant to future calculations of settlement 

h] amounts. 

20 It should be noted that other methods for computing the settlement amount may be 

O used in the FIG. 27A and FIG. 27B process steps. For example, in a case that the settlement 

price 820 established with a retailer is the agreement price, and the agreement price is a price 
per gallon, the settlement amount corresponding to a customer is equal to an agreement price 
per gallon established with the customer multiplied by the number of gallons redeemed at the 

25 retailer by the customer. It should also be noted that redemption information may be received 
from a retailer without any customer-identifying information. That is, a retailer may simply 
transmit information indicating a number of gallons of various products redeemed under 
various customer agreements with the controller 200. Accordingly, the controller 200 then 
determines the settlement amount due to the retailer based on this information and other 

30 information stored in the databases of the controller 200. 

ADDITIONAL EMBODIMENTS 

The following are several examples which illustrate additional embodiments of the 
present invention. These examples do not constitute a definition of all possible embodiments, 
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and those skilled in the art will understand that the present invention is applicable to many 
other embodiments. Further, although the following examples are briefly described for 
clarity, those skilled in the art will understand how to make any changes, if necessary, to the 
above-described embodiments to accommodate these and other embodiments and 
5 applications. 

In one embodiment, the controller 200 may establish an agreement with a travel 
association such as AAA® to sell gasoline to association members. For example, upon 
receiving notification from a member that the member will be taking a particular automobile 
trip, AAA® offers a special deal to the customer where he may prepay for a number of units 
10 of gasohne which can be redeemed at certain participating retailers along the way. The 
member may be eligible for special agreement prices or a special customer segment, and 
retailers may pay to participate. 

In another embodiment, an agreement price decreases during redemption under an 
agreement. For example, a customer may pay $1 .30 per gallon for a first 10 gallons under an 
- 15 agreement, $1 .20 for a next 10 gallons, and so on. Accordingly, this scheme rewards a 
customer for completing an agreement. 

An agreement may also specify "fillups" rather than specific amounts of gasohne. In 
this regard, an agreement may specify a flat price, price per unit, or a percentage off a retail 
price for each fillup. If a customer who has agreed to 10 fillups at $1.25 per gallon redeems 
20 5.5 gallons during a redemption, the customer pays $6.88 and is left with 9 more fillups, at 
which any amount may be redeemed. 

The customer may be prohibited from redeeming a product different from an 
agreement product. Alternatively, a customer having redeemed a product different from an 
agreement product may be allowed to redeem the product but then charged a full retail price 
25 for the product, perhaps with a penalty, after the controller 200 receives an indication of the 
redemption. 

The agreement may specify different quantities of different products for a same 
agreement price. For example, the agreement price may be $50 for 60 gallons of 87 octane 
gasoline, 50 gallons of 89 octane, or 40 gallons of 93 octane. The particular agreement 
30 product would be the first product redeemed under the agreement, or the customer may be 
able to redeem any of the specified products during the life of the agreement. In the latter 
instance, the agreement price may correspond to a certain number of agreement points and a 
unit of each product would be worth a different number of points. 
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The customer may also be required to purchase a number of units of the agreement 
product at a retail price when redeeming the product under the agreement. For example, a 
customer redeeming 10 gallons of an agreement product may have to pay the retail price for 5 
gallons and the agreement price for the remaining 5 gallons. 
5 In order to determine a retailer or retailers to bind to an agreement, the controller 200 

may bundle several agreements and auction the bundle to participating retailers. The offers 
may be bundled according to one or more characteristics, such as time submitted, agreement 
product, or agreement price. A retailer may offer pa)mients to the controller 200 in exchange 
for a bundle of customers, hi addition, a retailer may be required to honor all offers in a 
10 bundle, or may choose which agreements from the bundle will be honored. 

In other embodiments, settlement prices and/or agreement prices may vary depending 
upon when a redemption occurs. For example, an agreement price may be lower if 
O redemption occurs during a weekday rather than a weekend. 

=1 As described above, a customer may be provided with a code to present prior to a 

15 redemption. The code may be stored in a database in conjunction with a "valid" status flag, 
y Once the code is presented for a redemption, the status flag is changed to "invalid" and a new 

'FJ code is provided to the customer. The new code is also stored in the database in conjunction 

;^ with a status flag changed from "invahd" to "valid". For embodiments in which benefits 
y increase during redemption under an agreement, each code can be associated with a different 

^ 20 benefit. For example, a first code provided to the customer before any redemption under an 
agreement may be associated with a $1 .50 per gallon agreement price, while a fourth code 
provided may be associated with a $1 .25 per gallon agreement price. 

One or more honoring retailers may be associated with different agreement prices. In 
this regard, a customer may pay $1.25 per gallon of gasoline redeemed under an agreement 
25 from a first retailer and $1 .30 per gallon of gasoline redeemed under the agreement from a 
second retailer. The agreement may specify a total desired quantity or may specify separate 
quantities for each retailer. In one embodiment, a customer redeems the agreement product 
from each honoring retailer using a same redemption identifier. 

In another embodiment, a redemption identifier corresponding to an agreement can be 
30 used to redeem gasoline from a retailer at which the agreement is not honored. For example, 
if the redemption identifier is embodied in a credit card, the retail price for a product 
redeemed at the non-honoring retailer will be deducted from an appropriate account tracked 
by the controller 200 without affecting corresponding agreement information. Alternatively, 
the agreement information may be updated by subtracting the amount redeemed from the 
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quantity remaining under the agreement. The agreement information may also be updated by 
subtracting a number of gallons from the quantity remaining which could have been 
redeemed at the agreement price for the retail price deducted from the customer's account. 
For example, if an agreement price is $1.25 and 10 gallons of gasoline were redeemed from a 
5 non-honoring retailer at $1.50 per gallon, ($15/$1.25) = 12 gallons of gasoline are deducted 
from the quantity remaining under the agreement. 

The redemption identifier may also be embodied in a smart card, in which case the 
smart card can store and process information other than that directly related to the product 
agreement, such as a customer's purchase history. For example, the smart card could track 
10 what offers were received by the customer and which of the offers were accepted. Retailers 
could use this information to tailor offers to the customer. 

One redemption identifier could relate to redemption of several products. For 
O example, a customer may use a single redemption identifier to redeem gasoline, oil, and 

111 wiper fluid, as long as the several products are each somehow associated with the redemption 
15 identifier. 

H A redemption identifier may also be given to a third party as a gift, allowing the third 

IS party to redeem an agreement product associated with the redemption identifier, hi this 

embodiment, the agreement price may be kept secret from the third party. For example, the 
kl customer terminal 400 displays a retail price during redemption rather than an agreement 
72 20 price. 

O In other embodiments, a customer is permitted to make ad hoc changes to an 

agreement. For example, if the price of gasoline drops from $2.00 per gallon to $ 1 .00 per 
gallon and an agreement has been established for an agreement price of $1.75 per gallon, the 
customer may renegotiate a new agreement price for the quantity remaining under the 
25 agreement, or a new agreement price may be automatically generated. Such an embodiment 
discourages agreement breakage and may encourage customers to establish agreements with 
the controller 200. On the other hand, an agreement may be void or unusable if retail prices 
reach a pre-specified level. For example, an agreement may specify that it is usable only if a 
retail price for the agreement product is less than $3.00 per gallon. 
30 hi another embodiment, the customer pays the agreement price only if the agreement 

price is less than a retail price for the agreement product. For example, an agreement price is 
compared to a current retail price when a customer submits a redemption identifier for a 
redemption. If the retail price is greater than the agreement price, the redemption proceeds 
according to an embodiment described herein. If the agreement price is greater than the retail 
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price, and both prices are prices per unit, the customer is refunded a difference between the 
agreement price and the retail price multiphed by the number of units redeemed. If the 
customer has not pre-paid for the agreement, the customer pays the retailer the retail price, 
hi some embodiments, all retailers are considered honoring retailers. That is, a 
5 customer may redeem the agreement product at any gasoline station and the controller 200 
will charge the customer the agreement price for the agreement product. According to these 
embodiments, the customer is provided with a credit card that is used to pay for an agreement 
product at any retailer. The controller 200 is notified of the credit card transaction and i) 
charges the customer the agreement price for the product, and ii) pays the retailer the retail 
1 0 price or a settlement price for the redeemed product. 

While the present invention has been described above with respect to several 
□ embodiments, the scope of the invention is not deemed limited to the above embodiments, 
m Rather, the present invention covers all embodiments falling within the scope and spirit of the 

15 following claims as well as equivalent arrangements thereof. 
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What is claimed is: 

1 1. A method comprising: 

2 establishing an agreement with a customer to provide X units of a product for an 

3 agreement price; 

4 arranging with a retailer to have the product redeemed at the retailer; and 

5 receiving data indicating a redemption of Y units of the product, 

6 wherein Y is a non-integer. 

1 2. A method according to Claim 1, wherein the agreement price is less than a current 

2 retail price offered by the retailer for the product. 

1 3. A method according to Claim 1, further comprising: 

2 receiving from the customer an offer to purchase the product for the agreement price; 

3 and 

4 indicating an acceptance of the offer. 

1 4. A method according to Claim 3, further comprising: 

2 determining whether to indicate the acceptance based on a difference between the 

3 agreement price and a settlement price to be paid to the retailer. 

1 5. A method according to Claim 1, further comprising: 

2 determining a difference between the agreement price and a settlement price to be 

3 paid to the retailer; and 

4 identifying a subsidy offer greater than the difference. 

1 6. A method according to Claim 1, further comprising: 

2 receiving from the customer a payment equal to the agreement price. 

1 7. A method according to Claim 6, wherein the payment is received 

2 in a plurality of installments. 

1 8. A method according to Claim 6, wherein the payment is received after the X units 

2 of the product are redeemed. 
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1 9. A method according to Claim 1, further comprising: 

2 paying the retailer a settlement amount after receiving the data indicating the 

3 redemption. 

1 1 0. A method according to Claim 9, wherein the agreement price is a price per unit of 

2 the product, and the settlement amount is equal to Y multiplied by (a current retail price per 

3 unit of the product minus the agreement price). 

1 1 1 . A method according to Claim 10, ftirther comprising receiving from the customer 

2 a payment equal to X multiplied by the agreement price. 

1 12. A method according to Claim 10, wherein the agreement price is a price per unit 

Q 2 of the product, and the settlement amount is equal to Y multipKed by (a predetermined price 

|1 3 per unit of the product minus the agreement price). 

-J 1 13. A method according to Claim 12, further comprising receiving from the customer 

^£1 2 a payment equal to X multiplied by the agreement price. 

h| 1 14. A method according to Claim 1, fiirther comprising: 

J^J 2 pa>ing the customer an amount paid by the customer to the retailer minus (the 

P 3 agreement price multiplied by Y), 

4 wherein the agreement price is a price per unit of the product. 

1 15. A method according to Claim 1, further comprising: 

2 transmitting to the retailer the agreement to provide X units of the product for the 

3 agreement price. 

1 16. A method according to Claim 1., fiirther comprising: 

2 receiving from the retailer a request for authorization to provide the product to the 

3 customer. 

1 17. A method according to Claim 16, fiirther comprising: 

2 retrieving agreement information corresponding to the agreement; and 

3 transmitting an authorization to the retailer to provide the product to the customer. 
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1 1 8. A method according to Claim 1 , further comprising: 

2 updating data indicating a quantity remaining imder the agreement based on the 

3 received data. 

1 19. A method to provide a product to a customer, comprising: 

2 receiving a redemption identifier; 

3 retrieving data indicating an agreement to provide X units of a product for a customer- 

4 specified agreement price based on the redemption identifier; 

5 authorizing a redemption of up to X units of the product; and 

6 receiving data indicating a redemption of Y units of the product, 

7 wherein Y is a non-integer. 

{ii 1 20. A method to provide a product to a customer, comprising: 

=1; 2 receiving a redemption identifier from a customer; 

S| 3 transmitting the redemption identifier to a controller; 

4 receiving authorization from the controller to provide up to X units of a product to the 

5 customer; 

ill 6 controlling a redemption device to stop dispensing the product after X units of the 

7 product have been dispensed; and 

O 8 determining whether the customer requests additional imits of the product. 

1 21 . A method to provide a product to a customer, comprising: 

2 controlling a redemption device to stop dispensing a product after X units of the 

3 product have been dispensed; 

4 establishing an agreement with a customer to redeem additional units of the product 

5 for an agreement price; 

6 storing information corresponding to the agreement; and 

7 providing the additional units to the customer. 

1 22. A method to provide a product to a customer, comprising: 

2 receiving a redemption identifier from a customer; 

3 retrieving data indicating an agreement to provide X units of a product for a customer- 

4 specified agreement price based on the redemption identifier; and 
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5 providing Y units of the product to the customer, 

6 wherein Y is a non-integer. 

1 23. A method according to Claim 22, further comprising receiving the data indicating 

2 an agreement to provide X units of a product for a customer-specified agreement price from a 

3 controller. 

1 24. A method according to Claim 22, further comprising determining a quantity 

2 remaining under the agreement. 

1 25. A method according to Claim 24, further comprising transmitting the determined 

2 quantity remaining to the customer. 

L 26. A method according to Claim 24, further comprising: 

r 2 controlling a product redemption device to stop dispensing the product once the 

3 quantity remaining has been redeemed. 

L 27. A method according to Claim 26, fvirther comprising receiving an offer to 

_ 2 purchase Z units of the product for the customer-specified agreement price once the quantity 

Q 3 remaining has been redeemed. 

1 28. A method according to Claim 26, further comprising receiving an offer to 

2 purchase X units of the product for a second customer-specified agreement price once the 

3 quantity remaining has been redeemed. 

1 29. A method according to Claim 26, further comprising receiving an offer to 

2 purchase Z units of the product for a second customer-specified agreement price once the 

3 quantity remaining has been redeemed. 

1 30. A method according to Claim 26, further comprising receiving an offer to 

2 purchase X units of the product for the customer-specified agreement price once the quantity 

3 remaining has been redeemed. 

1 31 . A method according to Claim 22, further comprising: 
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2 determining that an amount of the product redeemed by the customer exceeds a 

3 quantity remaining imder the agreement. 

1 32. A method according to Claim 3 1 , further comprising: 

2 calculating a difference between the amount of the product redeemed and the quantity 

3 remaining under the agreement; and 

4 extracting a payment from the customer equal to the difference multiplied by a retail 

5 price for the product. 

1 33. A method according to Claim 3 1 , further comprising: 

2 calculating a difference between the amount of the product redeemed and the quantity 

3 remaining under the agreement; and 

O 4 extracting a payment from the customer equal to (the agreement price multiplied by 

I i 5 the quantity remaining tmder the agreement) plus (the difference multiplied by a retail price 

% 6 for the product). 

; n 1 34. A method according to Claim 31, further comprising: 

2 calculating a difference between the amount of the product redeemed and the quantity 

m 3 remaining under the agreement; and 

Q. 4 extracting a payment from the customer equal to (the agreement price multiplied by 

^3 5 the quantity remaining under the agreement) plus (the difference multipUed by a retail price 

6 for the product) plus a penalty. 

1 35. A method according to Claim 31, further comprising: 

2 calculating a difference between the amount of the product redeemed and the quantity 

3 remaining under the agreement; and 

4 if the difference is less than a predetermined amount, extracting a payment from the 

5 customer equal to the agreement price multiplied by the difference. 

1 36. A method according to Claim 31, further comprising: 

2 calculating a difference between the amoimt of the product redeemed and the quantity 

3 remaining under the agreement; and 

4 if the difference is less than a predetermined amount, extracting a payment from the 

5 customer equal to the agreement price multiplied by the quantity redeemed. 
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1 37. A method according to Claim 22, further comprising transmitting data indicating 

2 the redemption of Y units to a controller. 

1 38. A method according to Claim 22, further comprising receiving a payment from 

2 the customer, the payment based on a current retail price offered by the retailer per unit of the 

3 product multiplied by Y. 

1 39. A method according to Claim 22, wherein the agreement price is a price per unit, 

2 the method further comprising receiving a payment from the customer based on the 

3 agreement price multiplied by Y. 

O 1 40. A method according to Claim 39, further comprising receiving a payment from a 

111 2 third party, the payment based on Y multiplied by (a settlement price per unit established 

3 with the third party minus the agreement price) . 

7n 1 41. A method according to Claim 22, further comprising receiving a payment from a 

'L, 2 third party, the payment based on a settlement price per unit established with the third party 

ill 3 multiplied by Y. 

Q 1 42. A method according to Claim 22, further comprising transmitting data indicating 

2 a received payment and the Y redeemed units to a third party. 

1 43. A method according to Claim 22, fiarther comprising controlling a redemption 

2 device to provide the product to the customer for the agreement price. 

1 44. A method according to Claim 22, further comprising updating the data indicating 

2 the agreement based on the redemption. 

1 45. A method according to Claim 44, further comprising: 

2 generating a second redemption identifier encoding the updated data; and 

3 outputting the second redemption identifier to the customer. 
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1 46. Computer-executable process steps stored on a computer-readable medium, the 

2 process steps comprising: 

3 an establishing step to establish an agreement with a customer to provide X units of a 

4 product for an agreement price; 

5 an arranging step to arrange with a retailer to have the product redeemed at the 

6 retailer; and 

7 a receiving step to receive data indicating a redemption of Y units of the product, 

8 wherein Y is a non-integer. 

1 47. Computer-executable process steps stored on a computer-readable medium, the 

2 process steps comprising: 

3 a receiving step to receive a redemption identifier; 

III 4 a retrieving step to retrieve data indicating an agreement to provide X units of a 

i f! 5 product for a customer-specified agreement price based on the redemption identifier; 
J: 6 an authorizing step to authorize a redemption of up to X units of the product; and 

S.I 7 a receiving step to receive data indicating a redemption of Y units of the product, 

8 wherein Y is a non-integer. 

y 1 48. Computer-executable process steps stored on a computer-readable medium, the 

2 process steps comprising: 
?3 3 a receiving step to receive a redemption identifier fi-om a customer; 

4 a transmitting step to transmit the redemption identifier to a controller; 

5 a receiving step to receive authorization fi-om the controller to provide up to X units 

6 of a product to the customer; 

7 a controlling step to control a redemption device to stop dispensing the product after 

8 X units of the product have been dispensed; and 

9 a determining step to determine whether the customer requests additional units of the 
10 product. 

1 49. Computer-executable process steps stored on a computer-readable medium, the 

2 process steps comprising; 

3 a controlling step to control a redemption device to stop dispensing a product after X 

4 units of the product have been dispensed; 
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5 an establishing step to establish an agreement with a customer to redeem additional 

6 units of the product for an agreement price; 

7 a storing step to store information corresponding to the agreement; and 

8 a providing step to provide the additional units to the customer. 

1 50. Computer-executable process steps stored on a computer-readable medium, the 

2 process step comprising: 

3 a receiving step to receive a redemption identifier from a customer; 

4 a re trieving step to retrieve data indicating an agreement to provide X units of a 

5 product for a customer-specified agreement price based on the redemption identifier; and 

6 a providing step to provide Y units of the product to the customer, 

7 wherein Y is a non-integer. 

1 51. An apparatus comprising: 

=P 2 means for creating an agreement with a customer to provide X units of a product for 

3 an agreement price; 

■i 4 means for planning with a retailer to have the product redeemed at the retailer; and 

5 means for receiving data indicating a redemption of Y units of the product, wherein Y 

h| 6 is a non-integer. 

O 1 52. An apparatus for providing a product to a customer, comprising: 

2 means for obtaining a redemption identifier; 

3 means for obtaining data indicating an agreement to provide X units of a product for a 

4 customer-specified agreement price based on the redemption identifier; 

5 means for allowing a redemption of up to X units of the product; and 

6 means for obtaining data indicating a redemption of Y xmits of the product, wherein Y 

7 is a non-integer. 

1 53. An apparatus for providing a product to a customer, comprising: 

2 means for obtaining a redemption identifier from a customer; 

3 means for delivering the redemption identifier to a controller; 

4 means for obtaining authorization from the controller to provide up to X imits of a 

5 product to the customer; 
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6 means for managing a redemption device to stop dispensing the product after X units 

7 of the product have been dispensed; and 

8 means for identifying whether the customer requests additional units of the product. 

1 54. An apparatus for providing a product to a customer, comprising: 

2 means for managing a redemption device to stop dispensing a product after X units of 

3 the product have been dispensed; 

4 means for creating an agreement with a customer to redeem additional units of the 

5 product for an agreement price; 

6 means for saving information corresponding to the agreement; and 

7 means for deHvering the additional imits to the customer. 

□ 1 55. An apparatus for providing a product to a customer, comprising: 

2 means for obtaining a redemption identifier from a customer; 

3 means for obtaining data indicating an agreement to provide X units of a product for a 
'=a 4 customer-specified agreement price based on the redemption identifier; and 

5 means for delivering Y units of the product to the customer, wherein Y is a non- 

'L, 6 integer. 

JT 1 56. A method for redeeming a product, comprising: 

Q 2 receiving an offer to purchase a number of units of an offer product for an offer price; 

3 indicating an acceptance of the offer; 

4 transmitting a redemption identifier associated with the offer; 

5 receiving the redemption identifier and data indicating a desired product; 

6 determining if the desired product is equivalent to the offer product; 

7 authorizing a redemption of the number of units of the product if the desired product 

8 is equivalent to the offer product; and 

9 receiving data indicating a redemption of a firactional number of units of the product, 
10 the fractional number less than the number of units. 

1 57. An apparatus comprising: 

2 a processor; and 

3 a memory in communication with the processor, the memory storing processor- 

4 executable process steps, 
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5 wherein the processor is operative with the process steps to: 

6 i) receive an offer to purchase a number of units of an offer product for an offer price; 

7 ii) indicate an acceptance of the offer; 

8 iii) transmit a redemption identifier associated with the offer; 

9 iv) receive the redemption identifier and data indicating a desired product; 

1 0 v) determine if the desired product is equivalent to the offer product; 

1 1 vi) authorize a redemption of the number of units of the product if the desired product 

12 is equivalent to the offer product; and 

1 3 vii) receive data indicating a redemption of a fi-actional number of units of the 

14 product, the fractional number less than the number of units. 
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ABSTRACT 

A system to provide a product to a customer includes, in one aspect, establishment of 
an agreement with a customer to provide a number of units of a product for an agreement 
price, arrangement with a retailer to have the product redeemed at the retailer, and reception 
of data indicating a redemption of a fractional number of imits of the product. 
Advantageously, customer behavior can thereby be influenced in a retailer's favor and a 
retailer is provided with indications of future demand. In addition, a customer is provided 
with convenience, protection against price increases, and an abiUty to pay less than a retail 
price for a product. 
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n 






T 








Full name of ninth inventor, if any 






Ninth inventor's signature 


Date 




i 


Residence 






Citizenship 






Post Office Address 


















Full name of tenth inventor, if any 






Tenth inventor's signature Date 






Residence 






Citizenship 






Post Office Address 
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